Article

【spring springmvc】springmvc使用注解声明控制器与请求映射

围绕工程实践、云原生与开发经验的深度整理。

【spring springmvc】springmvc使用注解声明控制器与请求映射

概述

注解: 在 Spring 中尽管使用 XML 配置文件可以实现 Bean 的装配工作,但如果应用中 Bean 的数量较多,会导致 XML 配置文件过于臃肿,从而给维护和升级带来一定的困难。 从 JDK 5 开始提供了名为 Annotation(注解)的功能,Spring 正是利用这一特性,Spring 逐步完善对 Annotation 注解技术的全面支持,使 XML 配置文件不再臃肿,向“零配置”迈进。

Spring 框架也为表示层提供了一个优秀的 Web 框架,即 Spring MVC。由于 Spring MVC 采用了松耦合可插拔组件结构,比其他 MVC 框架具有更大的扩展性和灵活性。通过注解,Spring MVC 使得 POJO 成为处理用户请求的控制器,无需实现任何接口。

壹:注解说明

Spring 中定义了一系列的 Annotation 注解,如下所示:

注解名称说明
@Component 注解@Component 是一个泛化的概念,仅仅表示一个组件(Bean),可以作用在任何层次。
@Repository 注解@Repository 注解用于将数据访问层(DAO 层)的类标识为 Spring 的 Bean。
@Service 注解@Service 通常作用在业务层,但是目前该功能与@Component 相同。
@Controller 注解@Controller 标识表示层组件,但是目前该功能与@Component 相同
@Autowired 注解用于对 Bean 的属性变量、属性的 set 方法及构造函数进行标注,配合对应的注解处理器完成 Bean 的自动配置工作。@Autowired 注解默认按照 Bean 类型进行装配。@Autowired 注解加上@Qualifier 注解,可直接指定一个 Bean 实例名称来进行装配。
@Resource 注解作用相当于@Autowired,配置对应的注解处理器完成 Bean 的自动配置工作。区别在于:①:@Autowired 默认按照 Bean 类型进行装配,②:@Resource 默认按照 Bean 实例名称进行装配。

贰:实现注解声明控制器与请求映射

一:使用 controller

org.springframework.stereotype.Controller 注解类型用于指示 Spring 类的实例是一个控制器,其注解形式为@Controller。该注解在使用时不需要再实现 Controller 接口,只需要将@Controller 注解加入到控制器类上,然后通过 Spring 的扫描机制找到标注了该注解的控制器即可。

@Controller
public class SpringController {
    @GetMapping("/helloWorld")
    public String hello(){
        System.out.println("hello.....");
        return "hello";
    }
}

我们常用的 rest 风格请求(REST : 即 Representational State Transfer 。(资源)表现层状态转化):

请求说明用于
@GetMapping匹配 GET 方式的请求;一般读取数据
@PostMapping匹配 POST 方式的请求;一般用于插入数据
@PutMapping匹配 PUT 方式的请求;一般用于更新数据
@DeleteMapping匹配 DELETE 方式的请求;一般用于删除数据

二:配置包扫描与视图解析器

1、配置包扫描

虽然哦我们已经 i 邪恶好了 controller,但是直接这样写我们是不能用的,还需要在spring-mvc.xml配置文件中,用 spring 的包扫描将他注入到容器中,我们才能实现调用。

    <!--使用扫描机制 -->
    <context:annotation-config/>
    <context:component-scan base-package="com.lomtom.controller"/>
    当然,spring提供了很多种方法,我们是用最简单实现的就可以。

2、配置试图解析器

SpringMVC 中的视图解析器的主要作用就是将逻辑视图转换成用户可以看到的物理视图。 在spring-mvc.xml加入试图解析器,其中的前缀就是根据自己的文件存放目录来写,后缀就是你的文件的后缀名,你可以是.jsp、.html 等等。

    <!--    配置视图解析器 prefix:前缀, suffix:后缀-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/"></property>
        <property name="suffix" value=".html"></property>
    </bean>

三:配置部署描述符

Deployment Descriptors(描述符)是一个 xml 文件,用来描述如何部署一个模块或者应用(根据描述符中定义的配置和容器选项)。 在这里简单来说就是我们的web.xml

1、读取 spring-mvc.xml 文件

虽然,我们已经把 controller 通过 spring-mvc.xml 注入到容器中,相信这时你启动项目时,是访问不了的 controller 的请求的,也就是说,我们的我没在配置该文件,这时候在你的 web.xml 中加入。

如果我们不指定 SpringMVC 配置文件的路径,则会自动到 WEB-INF 下找 ‘‘前端控制器名-servlet.xml’’ 这个文件,如果找不到则会报错。

    <!--    配置Spring MVC配置文件-->
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:spring-mvc.xml</param-value>
    </init-param>

2、配置匹配映射

servlet: 它提供静态资源。它处理所有未映射到其他带有 servlet 映射的 servlet(在这里或在您自己的-web.xml 文件)。

servlet-mapping: 当为静态资源提供服务时,Tomcat 将自动生成基于资源文件扩展名的“Content Type”头,基于这些映射。可以在此处添加其他映射(到应用于所有 web 应用程序),或在您自己的应用程序的 web.xml 中部署描述符。

<!-- 配置DispatcherServlet -->
<servlet>
   <servlet-name>dispatcherServlet</servlet-name>
   <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
 </servlet>

 <!-- ServLet 匹配映射 -->
 <servlet-mapping>
   <servlet-name>dispatcherServlet</servlet-name>
   <url-pattern>/</url-pattern>
 </servlet-mapping>

四:建立 html 文件

新建两个文件,用于访问测试,一个 index.html,写一个连接指向href=“helloWorld”,写另一个 hello.html,用于访问成功后,跳转到该页面。

叁:配置 tomcat

在这里,作者摸索到了两种配置 tomcat 的方法,一种就是本地自个的 tomcat,还有一种就是 maven 提供的 tomcat 容器。

一:配置本地 tomcat

基本上就是这几步,其中的选择 tomcat 目录省略了,不是很难,添加服务就可以,找不到入口就算了,请不要打我。如果你配置 tomcat 也不会,那么,现在放下电脑去打把王者荣耀吧,妲己可能会告诉你。 tomcat

二:配置 maven 内置 tomcat

配置 maven 的 tomcat 相对会麻烦一点,不过也不是很麻烦,在你的 pom.xml 文件中加入一下插件依赖。

<plugins>
	<plugin>
	    <groupId>org.apache.tomcat.maven</groupId>
	    <artifactId>tomcat7-maven-plugin</artifactId>
	    <version>2.2</version>
	</plugin>
</plugins>

然后,添加配置,需要注意的是,你需要配置你的 maven,在下图的 General 里面,如果你已经使用了 maven,就不用配了,可以查看 General 下配置是否正确。 安装与配置 maven:传送门 🔗 maven-tomcat 接下来你就可以启动你的项目了,祝你能够一步成功,哈哈哈哈。

肆:结果及问题

一:tomcat 启动示意图:

本地 tomcat: maven 内置 tomcat:

二:结果

首页:首页 死案及后跳转: hello

三:问题

1、解决 SpringMVC 不能访问 html 页面

<servlet-mapping>
	<servlet-name>default</servlet-name>
	<url-pattern>*.html</url-pattern>
</servlet-mapping>

2、使用 maven 内置 tomcat 有时能跳转,有时不能跳转,不能跳转的时候他会卡在读取文件这里,这里对不起了,笔者没找到解决方法,如果你找到了,欢迎告诉笔者。

三月 21, 2020 1:02:09 下午 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
信息: Loading XML bean definitions from class path resource [spring-mvc.xml]

该问题追加:

根据 csdn 评论中大佬的解决方法,我重新试了一下,后来发现问题根源,发现项目根本找不到spring-context.xsd,导致 spring-mvc.xml 文件加载出错,并且造成通配符的匹配很全面, 但无法找到元素 'context:annotation-config' 的声明的错误,所以项目一直在加载spring-mvc.xml文件,这时我就意识到是我的spring-mvc.xml中的引入出问题了,经过修改,问题解决了。

修改前:
https://www.springframework.org/schema/context/spring-context.xsd
修改后:
http://www.springframework.org/schema/context/spring-context.xsd

伍:结构及源码

源码都放出来了,还不是 ctrl+c,ctrl+v 一顿乱搞。

一:目录结构

目录结构

二:源码

1、controller

package com.lomtom.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

/**
 * @Author: LOMTOM
 * @Date: 2020/3/20
 * @Time: 18:40
 * @Email: lomtom@lomtom.cn
 */
@Controller
public class SpringController {
    @GetMapping("/helloWorld")
    public String hello(){
        System.out.println("hello.....");
        return "hello";
    }
}

2、spring-mvc.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/mvc
       http://www.springframework.org/schema/mvc/spring-mvc.xsd
       http://www.springframework.org/schema/context
       https://www.springframework.org/schema/context/spring-context.xsd">

    <mvc:annotation-driven/>

    <!--使用扫描机制 -->
    <context:annotation-config/>
    <context:component-scan base-package="com.lomtom.controller"/>

    <!--    配置视图解析器 prefix:前缀, suffix:后缀-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/"></property>
        <property name="suffix" value=".html"></property>
    </bean>
</beans>

3、web.xml

<!DOCTYPE web-app PUBLIC
 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
 "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
  <display-name>Archetype Created Web Application</display-name>
  <servlet>
    <!-- 配置DispatcherServlet -->
    <servlet-name>dispatcherServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

    <!-- 指定spring mvc配置文件位置 不指定使用默认情况 -->
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:spring-mvc.xml</param-value>
    </init-param>
  </servlet>
  <!-- ServLet 匹配映射 -->
  <servlet-mapping>
    <servlet-name>dispatcherServlet</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>
  <servlet-mapping>
    <servlet-name>default</servlet-name>
    <url-pattern>*.html</url-pattern>
  </servlet-mapping>
</web-app>

4、pom.xml

<?xml version="1.0" encoding="UTF-8"?>

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>spring</artifactId>
        <groupId>spring</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>spring-8</artifactId>
    <packaging>war</packaging>

    <name>spring-8 Maven Webapp</name>
    <!-- FIXME change it to the project's website -->
    <url>http://www.example.com</url>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.11</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>4.3.1.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>4.3.1.RELEASE</version>
        </dependency>
    </dependencies>

    <build>
        <finalName>spring-8</finalName>
        <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
            <plugins>
                <plugin>
                    <groupId>org.apache.tomcat.maven</groupId>
                    <artifactId>tomcat7-maven-plugin</artifactId>
                    <version>2.2</version>
                </plugin>
                <plugin>
                    <artifactId>maven-clean-plugin</artifactId>
                    <version>3.1.0</version>
                </plugin>
                <!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging -->
                <plugin>
                    <artifactId>maven-resources-plugin</artifactId>
                    <version>3.0.2</version>
                </plugin>
                <plugin>
                    <artifactId>maven-compiler-plugin</artifactId>
                    <version>3.8.0</version>
                </plugin>
                <plugin>
                    <artifactId>maven-surefire-plugin</artifactId>
                    <version>2.22.1</version>
                </plugin>
                <plugin>
                    <artifactId>maven-war-plugin</artifactId>
                    <version>3.2.2</version>
                </plugin>
                <plugin>
                    <artifactId>maven-install-plugin</artifactId>
                    <version>2.5.2</version>
                </plugin>
                <plugin>
                    <artifactId>maven-deploy-plugin</artifactId>
                    <version>2.8.2</version>
                </plugin>
            </plugins>
        </pluginManagement>
    </build>
</project>

5、html

1、index.html
<html>
  <body>
    <h2>Hello World!</h2>
    <a href="helloWorld">hello</a>
  </body>
</html>

2、hello.html
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>hello</title>
  </head>
  <body>
    <h2>你好啊,你成功了</h2>
  </body>
</html>

作者有话

这篇文章,作者已经肝了很久了,如果对你有用的话,点个赞再走吧,不说了,作者要交作业去了。

标题:【spring springmvc】springmvc使用注解声明控制器与请求映射

作者:lomtom

链接:https://lomtom.cn /spring-springmvcspringmvc使用注解声明控制器与请求映射