SpringMVC注解使用

准备工作

  1. 添加maven依赖
		<dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>5.3.1</version>
        </dependency>
  1. 在工程中添加web支持(Tomcat服务器)
    在这里插入图片描述
  2. 配置web下web.xml,注册DispatcherServlet,并且绑定springMVC配置文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">

    <!--1.注册DispatcherServlet-->
    <servlet>
        <servlet-name>spring-mvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!--通过初始化参数指定SpringMVC配置文件的位置,关联一个springmvc的配置文件-->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:spring-mvc</param-value>
        </init-param>
        <!--启动级别-1,启动顺序,数字越小,启动越早-->
        <load-on-startup>1</load-on-startup>
    </servlet>
     <!--设置请求被springmvc拦截--> 
    <servlet-mapping>
        <!--/ 匹配所有的请求;(不包括.jsp)-->
        <!--/* 匹配所有的请求;(包括.jsp)-->
        <servlet-name>spring-mvc</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>
</web-app>

注意:

/*会匹配 *.jsp,会出现返回 jsp视图 时再次进入spring的DispatcherServlet 类,导致找不到对应的controller所以报404错

  1. 编写SpringMVC的配置文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:aop="http://www.springframework.org/schema/aop" xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        https://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/aop
        https://www.springframework.org/schema/aop/spring-aop.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!--开启mvc注解驱动-->
    <mvc:annotation-driven/>
<!--让Spring MVC不处理静态资源-->
    <mvc:default-servlet-handler/>
<!--自动扫描包,让指定包下的注解生效,由SpringIOC容器统一管理 -->
    <context:component-scan base-package="com.chenhui.controller"/>


<!--配置视图解析器-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver">
        <!--    前缀    -->
        <property name="prefix" value="WEB-INF/jsp/"/>
        <!--        后缀-->
        <property name="suffix" value=".jsp"/>
    </bean>



</beans>

注意:在视图解析器中我们把所有的视图都存放在/WEB-INF/目录下,这样可以保证视图安全,因为这个目录下的文件,客户端不能直接访问

  1. 创建Controller
//被这个注解的类中所有的方法,如果返回值是String,并且有具体页面可以跳转,那么就会被视图解析器解析
@Controller
public class HelloController {
    
    
    //真实访问地址 : http://localhost/项目名/hello
    @RequestMapping("/hello")
    public String test(Model model){
    
    
        //向模型中添加属性msg与值
        model.addAttribute("msg","Hello SpringMVC");
        //寻找视图:WEB-INF/jsp/hello.jsp
        return "hello";
    }
}
  • 添加注解@Controller是为了让Spring IOC容器初始化时自动扫描到
  • 添加@RequestMapping是为了映射请求路径,可以在类中和方法中添加使用,这里因为只有方法上有映射所以访问时应该是/hello;
  • 方法中声明Model类型的参数是为了把model中的数据带到视图中
  • 方法返回的结果是视图的名称hello,加上配置文件中视图解析器的前后缀变成WEB-INF/jsp/hello.jsp
  1. 创建视图层

在WEB-INF/ jsp目录中创建hello.jsp , 视图可以直接取出并展示从Controller带回的信息,可以通过EL表达式取出Model中存放的值,或者对象

<%--
  Created by IntelliJ IDEA.
  User: LEGION
  Date: 2021/3/2
  Time: 10:07
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<%--取值(Model中存入的值)--%>
${msg}
</body>
</html>

  1. 启动Tomcat,访问对应的请求路径
    在这里插入图片描述
    使用springMVC必须配置的三大件:
    处理器映射器、处理器适配器、视图解析器

通常,我们只需要手动配置视图解析器,而处理器映射器和处理器适配器只需要开启注解驱动即可,而省去了大段的xml配置

@Controller
public class HelloController {
    
    
    //真实访问地址 : http://localhost/项目名/hello
    @RequestMapping("/hello")
    public String test(Model model){
    
    
        //向模型中添加属性msg与值
        model.addAttribute("msg","Hello SpringMVC");
        //寻找视图:WEB-INF/jsp/hello.jsp
        return "hello";
    }

    @RequestMapping("/hello2")
    public String test2(Model model){
    
    
        //向模型中添加属性msg与值
        model.addAttribute("msg","SpringMVC");
        //寻找视图:WEB-INF/jsp/hello.jsp
        return "hello";
    }

}

在这里插入图片描述
可以发现,一个Controller类中可以定义多个方法的不同请求路径,不同的请求路径都可以指向一个视图,,但是页面结果的结果是不一样的,从这里可以看出视图是被复用的,而控制器与视图之间是弱偶合关系。

@RequestMapping作用

  • @RequestMapping注解用于映射url到控制器类或一个特定的处理程序方法。可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径
  1. 只注解在方法上面
@Controller
public class HelloController {
    
    
    //真实访问地址 : http://localhost/项目名/hello
    @RequestMapping("/hello")
    public String test(Model model){
    
    
        //向模型中添加属性msg与值
        model.addAttribute("msg","Hello SpringMVC");
        //寻找视图:WEB-INF/jsp/hello.jsp
        return "hello";
    }
}    

真实访问地址 : http://localhost/项目名/hello

  1. 同时注解类与方法
@Controller
@RequestMapping("/index")
public class HelloController {
    
    
    @RequestMapping("/hello")
    public String test(Model model){
    
    
        //向模型中添加属性msg与值
        model.addAttribute("msg","Hello SpringMVC");
        //寻找视图:WEB-INF/jsp/hello.jsp
        return "hello";
    }
}    

真实访问地址 : http://localhost/项目名/index/hello, 需要先指定类的路径再指定方法的路径

猜你喜欢

转载自blog.csdn.net/weixin_45608165/article/details/114288685