SpringMVC学习笔记01

1.什么是SpringMVC

1.1 回顾MVC

  1. 什么是MVC?
  • MVC是模型(Model),视图(View),控制器(Controller)的简写,是一种软件设计规范
  • 是将业务逻辑、数据、显示分离的方法来组织代码
  • MVC的主要作用是降低了视图与业务逻辑间的双向耦合
  • MVC不是一种设计模式,MVC是一种架构模式,当然不同的MVC存在差异

Model(模型):数据模型,提供要展示的数据,因此包含数据和行为,可以认为是领域模型或JavaBean组件(包含数据和行为)不过现在都分离开来:Value Object(数据Dao) 和服务层(行为Service),也就是模型提供了模型数据查询和模型数据的状态更新等功能,包含数据和业务

View(视图):负责进行模型的展示,一般就是我们见到的用户界面,客户想看到的东西

Controller(控制器):接收用户请求,委托给模型进行处理(状态改变),处理完毕后把返回的模型数据返回给视图,由视图负责展示,也就是说控制器做了个调度员的工作

最典型的MVC就是JSP+servlet+javabean的模式

SpringMVC学习笔记01 - 图1

  1. Model1时代
  • 在web的早期的开发中,通常采用的是Model1
  • Model1中,主要分为两层,视图层和模型层

SpringMVC学习笔记01 - 图2

Model1优点:架构简单,比较适合小型项目开发

Model1缺点:JSP职责不单一,职责过重,不便于维护

  1. Model2时代

Model2把一个项目分成三部分,包括视图,控制,模型

SpringMVC学习笔记01 - 图3

  1. 用户发请求
  2. Servlet接收请求数据,并调用对应的业务逻辑方法
  3. 业务处理完毕,返回更新后的数据给servlet
  4. servlet转向JSP,由JSP来渲染页面
  5. 响应给前端更新后的页面

职责分析

Controller:控制器

  1. 取得表单数据
  2. 调用业务逻辑
  3. 转向指定的页面

Model:模型

  1. 业务逻辑
  2. 保存数据的状态

View: 视图

  1. 显示页面

Model2这样不仅提高代码的复用率与项目的扩展性,且大大降低了项目的维护成本

Model1的实现比较简单,适用于快速开发小规模项目,Model1中JSP页面身兼View和Controller两种角色,将控制逻辑和表现逻辑混杂在一起,从而导致代码的重用性非常低,增加了应用的扩展性和维护的难度。Model2消除了Model1的缺点

  1. 回顾servlet

  2. 新建一个Maven工程当作父工程,导入依赖

  1. <dependencies>
  2. <dependency>
  3. <groupId>junit</groupId>
  4. <artifactId>junit</artifactId>
  5. <version>4.12</version>
  6. </dependency>
  7. <dependency>
  8. <groupId>org.springframework</groupId>
  9. <artifactId>spring-webmvc</artifactId>
  10. <version>5.1.9.RELEASE</version>
  11. </dependency>
  12. <dependency>
  13. <groupId>javax.servlet</groupId>
  14. <artifactId>servlet-api</artifactId>
  15. <version>2.5</version>
  16. </dependency>
  17. <dependency>
  18. <groupId>javax.servlet.jsp</groupId>
  19. <artifactId>jsp-api</artifactId>
  20. <version>2.2</version>
  21. </dependency>
  22. <dependency>
  23. <groupId>javax.servlet</groupId>
  24. <artifactId>jstl</artifactId>
  25. <version>1.2</version>
  26. </dependency>
  27. </dependencies>
  1. 建立一个Module子模块:springmvc-01,添加web-app的支持

SpringMVC学习笔记01 - 图4

  1. 导入servlet和jsp的jar依赖(如果父工程已经导入,则此步忽略)
  1. <dependency>
  2. <groupId>javax.servlet</groupId>
  3. <artifactId>servlet-api</artifactId>
  4. <version>2.5</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>javax.servlet.jsp</groupId>
  8. <artifactId>jsp-api</artifactId>
  9. <version>2.2</version>
  10. </dependency>
  1. 新建一个HelloServlet类,用来处理用户的请求
  1. public class HelloServlet extends HttpServlet {
  2. @Override
  3. protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  4. //1. 获取前端参数
  5. String method=req.getParameter("method");
  6. if(method.equals("add")){
  7. req.getSession().setAttribute("msg","执行了add方法");
  8. }
  9. if(method.equals("delete")){
  10. req.getSession().setAttribute("msg","执行了delete方法");
  11. }
  12. //2.调用业务层
  13. //3.视图转发或者重定向
  14. req.getRequestDispatcher("/WEB-INF/jsp/hello.jsp").forward(req,resp);
  15. }
  16. @Override
  17. protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  18. doGet(req, resp);
  19. }
  20. }
  1. 编写hello.jsp,在WEB-INF目录下新建一个jsp的文件夹。新建hello.jsp
  1. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  2. <html>
  3. <head>
  4. <title>jcsune</title>
  5. </head>
  6. <body>
  7. ${msg}
  8. </body>
  9. </html>
  1. 在web.xml中注册Servlet
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
  5. version="4.0">
  6. <servlet>
  7. <servlet-name>HelloServlet</servlet-name>
  8. <servlet-class>com.jcsune.servlet.HelloServlet</servlet-class>
  9. </servlet>
  10. <servlet-mapping>
  11. <servlet-name>HelloServlet</servlet-name>
  12. <url-pattern>/user</url-pattern>
  13. </servlet-mapping>
  14. </web-app>
  1. 配置Tomcat,并启动测试
  • localhost:8080/user?method=add
  • localhost:8080/user?method=delete

SpringMVC学习笔记01 - 图5

MVC框架要做哪些事情

  1. 将url映射到java类或java类中的方法
  2. 封装用户提交的数据
  3. 处理请求—调用相关的业务处理—封装响应数据
  4. 将响应的数据进行渲染 jsp/html等表示层数据

说明:

常见的服务器端MVC框架有:Struts、Spring MVC、ASP.NET MVC、Zend Framework、JSF

常见前端MVC框架:vue、angularjs、react、backbone;由MVC演化出了另外一些模式如:MVP、MVVM 等等….

1.2 什么是SpringMVC

  1. 概述

SpringMVC是Spring Framework的一部分,是基于Java实现MVC的轻量级框架

SpringMVC的特点:

  1. 轻量级,简单易学
  2. 高效,基于请求响应的MVC框架
  3. 与Spring兼容性好,无缝结合
  4. 约定优于配置
  5. 功能强大:RESTful、数据验证、格式化、本地化,主题等
  6. 简洁灵活

Spring的web框架围绕DispatcherServlet[调度Servlet]设计

DispatcherServlet的作用是将请求分发到不同的处理器,从Spring2.5开始,使用Java5或者以上版本的用户可以采用基于注解形式进行开发,十分简洁

正因为SpringMVC好,简单,便捷,易学,天生和Spring无缝集成(使用SpringIoc和Aop),使用约定优于配置,能够进行简单的Junit测试,支持Restful风格,异常处理,本地化,国际化,数据验证,类型转换,拦截器等等,所以我们要学习

  1. 中心控制器

Spring的web框架围绕DispatcherServlet设计,DispatcherServlet的作用是将请求分发到不同的处理器,从Spring2.5开始,使用java 5或者以上版本的用户可以采用基于注解的controller声明方式

SpringMVC框架像许多其它MVC框架一样,以请求为驱动,围绕一个中心Servlet分派请求及提供其它功能,DispatcherServlet是一个实际的Servlet(它继承自Http Servlet基类)

SpringMVC的原理如下图所示:

SpringMVC学习笔记01 - 图6

当发起请求时被前置的控制器拦截到请求,根据请求参数生成代理请求,找到请求对应的实际控制器,控制器处理请求,创建数据模型,访问数据库,将模型响应给中心控制器,控制器使用模型与视图渲染视图结果,将结果返回给中心控制器,再将结果返回给请求者

  1. SpringMVC执行原理

SpringMVC学习笔记01 - 图7

图为SpringMVC的一个较完整的流程图,实线表示SpringMVC框架提供的技术,不需要开发者实现,虚线表示需要开发者实现

简要分析执行流程:

  1. DispatcherServlet表示前置控制器,是整个SpringMVC的控制中心,用户发出请求,DispatcherServlet接收请求并拦截请求

    我们假设请求的url为: http://localhost:8080/SpringMVC/hello

    如上url拆分成三部分:
    http://localhost:8080 服务器域名

    1. SpringMVC 部署在服务器上的web站点
    2. hello表示控制器
    3. **通过分析,如上url表示为:请求位于服务器localhost:8080上的SpringMVC站点的hello控制器**
  2. HandlerMapping为处理器映射,DispatcherServlet调用HandlerMapping,HandlerMapping根据请求url查找Handler

  3. HandlerMappingExecution表示具体的Handler,其主要作用是根据url查找控制器,如上url被查找控制器为:hello

  4. HandlerExecution将解析后的信息传递给DispatcherServlet,如解析控制器映射等

  5. HandlerAdapter表示处理器适配器,其按照特定的规则去执行Handler

  6. Handler让具体的Controller执行

  7. Controller将具体的执行信息返回给HandlerAdapter,如ModelAndView

  8. HandlerAdapter将视图逻辑名或模型传递给DispatcherServlet

  9. DispatcherServlet调用视图解析器(Viewresolver)来解析HandlerAdapter传递的逻辑视图名

  10. 视图解析器将解析的逻辑视图名传给DispatcherServlet

  11. Dispatcherservlet根据视图解析器解析的视图效果,调用具体的视图

  12. 最终视图呈现给用户

2.第一个MVC程序

2.1 配置版实现

配置版:

  1. 新建一个Module, springmvc-02,添加web的支持
  2. 确定导入了SpringMVC的依赖
  3. 配置web.xml,注册DispatcherServlet
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
  5. version="4.0">
  6. <!--1.注册DispatcherServlet-->
  7. <servlet>
  8. <servlet-name>springmvc</servlet-name>
  9. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  10. <!--关联一个springmvc的配置文件:【servlet-name】-servlet.xml-->
  11. <init-param>
  12. <param-name>contextConfigLocation</param-name>
  13. <param-value>classpath:springmvc-servlet.xml</param-value>
  14. </init-param>
  15. <!--启动级别-1-->
  16. <load-on-startup>1</load-on-startup>
  17. </servlet>
  18. <!--/ 匹配所有的请求;(不包括.jsp)-->
  19. <!--/* 匹配所有的请求;(包括.jsp)-->
  20. <servlet-mapping>
  21. <servlet-name>springmvc</servlet-name>
  22. <url-pattern>/</url-pattern>
  23. </servlet-mapping>
  24. </web-app>
  1. 编写SpringMVC的配置文件,名称:springmvc-servlet.xml
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://www.springframework.org/schema/beans
  5. http://www.springframework.org/schema/beans/spring-beans.xsd">
  6. </beans>
  1. 添加处理器映射器
  1. <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
  1. 添加处理器适配器
  1. <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
  1. 添加视图解析器
  1. <!-- 视图解析器-->
  2. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="InternalResourceViewResolver">
  3. <!--前缀-->
  4. <property name="prefix" value="/WEB-INF/jsp/"/>
  5. <!--后缀-->
  6. <property name="suffix" value=".jsp"/>
  7. </bean>
  1. 编写我们要操作业务Controller,要么实现Controller接口,要么增加注解:需要返回一个ModelAndView,装数据,封视图
  1. public class HelloController implements Controller {
  2. public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
  3. // ModelAndView 模型和视图
  4. ModelAndView mv = new ModelAndView();
  5. //封装对象,放在ModelAndView中。Model
  6. mv.addObject("msg","HelloSpringMVC!");
  7. //视图跳转
  8. mv.setViewName("hello"); //: /WEB-INF/jsp/hello.jsp
  9. return mv;
  10. }
  11. }
  1. 将自己的类交给SpringIOC容器,注册bean
  1. <!--Handler-->
  2. <bean id="/hello" class="com.kuang.controller.HelloController"/>
  1. 写要跳转的jsp页面,显示ModelLandView存放的数据,以及我们的正常页面
  1. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  2. <html>
  3. <head>
  4. <title>jcsune</title>
  5. </head>
  6. <body>
  7. ${msg}
  8. </body>
  9. </html>
  1. 配置Tomcat启动测试

SpringMVC学习笔记01 - 图8

可能遇到的问题:访问出现404,排查步骤:

  1. 查看控制台输出,看一下是不是缺少了什么jar包
  2. 如果jar包存在,显示无法输出,就在IDEA的项目发布中,添加lib依赖
  3. 重启Tomcat即可解决

然而实际开发中,我们多以注解实现,这才是SpringMVC的精髓

2.2 注解版实现

注解版

  1. 新建一个module: springmvc-03,添加web支持

  2. 在pom.xml文件引入相关的依赖:主要有Spring框架核心库、Spring MVC、servlet , JSTL等。我们在父依赖中已经引入了!

  3. 配置web.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
  5. version="4.0">
  6. <!--1.注册DispatcherServlet-->
  7. <servlet>
  8. <servlet-name>springmvc</servlet-name>
  9. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  10. <!--关联一个springmvc的配置文件:【servlet-name】-servlet.xml-->
  11. <init-param>
  12. <param-name>contextConfigLocation</param-name>
  13. <param-value>classpath:springmvc-servlet.xml</param-value>
  14. </init-param>
  15. <!--启动级别-1-->
  16. <load-on-startup>1</load-on-startup>
  17. </servlet>
  18. <!--/ 匹配所有的请求;(不包括.jsp)-->
  19. <!--/* 匹配所有的请求;(包括.jsp)-->
  20. <servlet-mapping>
  21. <servlet-name>springmvc</servlet-name>
  22. <url-pattern>/</url-pattern>
  23. </servlet-mapping>
  24. </web-app>

注意事项:

  • 注意web.xml版本问题,到最新版
  • 注册DispatcherServlet
  • 关联SpringMVC的配置文件
  • 启动级别为1
  • 映射路径为/【不要用/* 会404】
  1. 添加Spring MVC配置文件

在resource目录下添加springmvc-servlet.xml配置文件,配置的形式与Spring容器的配置基本类似,为了支持基于注解的IOC,设置了自动扫描包的功能,具体的配置信息如下:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans.xsd
  8. http://www.springframework.org/schema/context
  9. https://www.springframework.org/schema/context/spring-context.xsd
  10. http://www.springframework.org/schema/mvc
  11. https://www.springframework.org/schema/mvc/spring-mvc.xsd">
  12. <!-- 自动扫描包,让指定包下的注解生效,由IOC容器统一管理 -->
  13. <context:component-scan base-package="com.jcsune.controller"/>
  14. <!-- 让Spring MVC不处理静态资源 -->
  15. <mvc:default-servlet-handler />
  16. <!--
  17. 支持mvc注解驱动
  18. 在spring中一般采用@RequestMapping注解来完成映射关系
  19. 要想使@RequestMapping注解生效
  20. 必须向上下文中注册DefaultAnnotationHandlerMapping
  21. 和一个AnnotationMethodHandlerAdapter实例
  22. 这两个实例分别在类级别和方法级别处理。
  23. 而annotation-driven配置帮助我们自动完成上述两个实例的注入。
  24. -->
  25. <mvc:annotation-driven />
  26. <!-- 视图解析器 -->
  27. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"
  28. id="internalResourceViewResolver">
  29. <!-- 前缀 -->
  30. <property name="prefix" value="/WEB-INF/jsp/" />
  31. <!-- 后缀 -->
  32. <property name="suffix" value=".jsp" />
  33. </bean>
  34. </beans>

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

  • 让IOC的注解生效
  • 静态资源过滤:HTML、 JS 、CSS 、图片、视频….
  • MVC的注解驱动
  • 配置视图解析器
  1. 创建Controller
  1. package com.jcsune.controller;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.ui.Model;
  4. import org.springframework.web.bind.annotation.RequestMapping;
  5. @Controller
  6. public class HelloController {
  7. @RequestMapping("/hello")
  8. public String hello(Model model){
  9. //封装数据
  10. model.addAttribute("msg","hello,SpringMVC");
  11. return "hello";//会被视图解析器处理
  12. }
  13. }
  1. 创建视图层

在WEB-INF/jsp目录中创建hello.jsp,视图可以直接取出并展示从Controller带回的信息

可以通过EL表示取出Model中存放的值,或者对象

  1. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  2. <html>
  3. <head>
  4. <title>jcsune</title>
  5. </head>
  6. <body>
  7. ${msg}
  8. </body>
  9. </html>
  1. 配置Tomcat运行

SpringMVC学习笔记01 - 图9

总结:

  1. 新建一个web项目
  2. 导入相关jar包
  3. 编写web.xml,注册DispatcherServlet
  4. 编写Springmvc配置文件
  5. 接下来就是去创建对应的控制类,controller
  6. 最后完善前端视图和controller之间的对应
  7. 测试运行调试

使用springmvc必须配置的三大件:

处理器映射器,处理器适配器,视图解析器

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

3.RestFul和控制器

3.1 使用接口Controller

控制器Controller

  • 控制器提供访问应用程序的行为,通常通过接口定义或注解定义两种方法实现
  • 控制器负责解析用户的请求并将其转换为一个模型
  • 在SpringMVC中一个控制器类可以包含多个方法
  • 在SpringMVC中,对于Controller的配置方式有很多种

实现Controller接口

Controller是一个接口,在org.springframework.web.servlet.mvc包下,接口中只有一个方法

  1. //实现该接口的类获得控制器功能
  2. public interface Controller {
  3. //处理请求且返回一个模型与视图对象
  4. ModelAndView handleRequest(HttpServletRequest var1, HttpServletResponse var2) throws Exception;
  5. }

测试:

  1. 新建一个module,springmvc-03,将之前的03拷贝一份,我们进行操作
  • 删掉HelloController
  • mvc的配置文件只留下视图解析器
  1. 编写一个Controller类,ControllerTest1
  1. //定义控制器
  2. //注意点:不要导错包,实现Controller接口,重写方法
  3. public class ControllerTest1 implements Controller {
  4. public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
  5. //返回一个模型视图对象
  6. ModelAndView mv=new ModelAndView();
  7. mv.addObject("msg","TestController1");
  8. mv.setViewName("hello");
  9. return mv;
  10. }
  11. }
  1. 编写完毕后,去Spring配置文件中注册请求的bean;name对应请求路径,class对应处理请求的类
  1. <bean name="/t1" class="com.jcsune.controller.ControllerTest1"/>
  1. 编写前端hello.jsp 注意在WEB-INF/jsp目录下编写,对应我们的视图解析器
  1. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  2. <html>
  3. <head>
  4. <title>jcsune</title>
  5. </head>
  6. <body>
  7. ${msg}
  8. </body>
  9. </html>
  1. 配置Tomcat运行测试,然而却出现了404!!!

SpringMVC学习笔记01 - 图10

经过查找,发现导包的时候,没有添加相关的依赖

SpringMVC学习笔记01 - 图11

添加相关的依赖后,再次测试:

SpringMVC学习笔记01 - 图12

说明:

  • 实现接口Controller定义控制器是较老的办法
  • 缺点:一个控制器中只有一个方法,如果要多个方法则需要定义多个Controller;定义的方式比较麻烦

3.2 使用注解@Controller

@Controller注解类型用于声明Spring类的实例是一个控制器(在学IOC时还提到了另外三个注解)

  1. @Component 组件
  2. @Service service
  3. @Controller controller
  4. @Repository dao

Spring可以使用扫描机制来找到应用程序中所有基于注解的控制器类,为了保证Spring能找到你的控制器,需要在配置文件中声明组件扫描

  1. <!--自动扫描指定的包,下面所有的注解类交给IOC容器管理-->
  2. <context:component-scan base-package="com.jcsune.controller"/>

增加一个ControllerTest2类,使用注解实现

  1. //@Controller注解的类会自动添加到Spring上下文中
  2. @Controller
  3. public class ControllerTest2 {
  4. //映射访问路径
  5. @RequestMapping("/t2")
  6. public String index(Model model){
  7. //Spring MVC会自动实例化一个Model对象用于向视图中传值
  8. model.addAttribute("msg","ControllerTest2");
  9. //返回视图位置
  10. return "hello";
  11. }
  12. }

运行Tomcat测试

SpringMVC学习笔记01 - 图13

这里我们可以发现:我们的两个请求都可以指向一个视图,但是页面显示的结果是不一样的。从这里可以看出视图是被复用的,而控制器与视图之间是弱耦合关系

注解方式是平时使用最多的方式!

3.3 RequestMapping

@RequestMapping注解用于映射url到控制器类或一个女特定的处理程序方法,可用于类或方法上,用于类上,表示类中所有吧响应请求的方法都是以该地址作为父路径

为了测试结论更加准确,我们可以新建一个类来测试:ControllerTest3

  • 只注解在方法上面
  1. @Controller
  2. public class ControllerTest3 {
  3. @RequestMapping("/t3")
  4. public String test(Model model){
  5. model.addAttribute("msg","ControllerTest3");
  6. return "hello";
  7. }
  8. }

访问路径:http://localhost:8080/t3

SpringMVC学习笔记01 - 图14

  • 同时注解类与方法
  1. @Controller
  2. @RequestMapping("/admin")
  3. public class ControllerTest3{
  4. @RequestMapping("/t3")
  5. public String test(Model model){
  6. model.addAttribute("msg","ControllerTest3");
  7. return "hello";
  8. }
  9. }

访问路径:http://localhost:8080/admin/t3 需要先指定类的路径再指定方法的路径

SpringMVC学习笔记01 - 图15

3.4 RestFul 风格

概念:

RestFul就是一个资源定位及资源操作的风格,不是标准也不是协议,只是一种风格,基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制

功能:

资源:互联网所有的事务都可以抽象为资源

资源操作:使用POST 、DELETE、PUT、GET使用不同方法对资源进行操作

分别对应添加、 删除 、修改 、 查询

传统方式操作资源:通过不同的参数来实现不同的效果!方法单一:post和get

  1. [http://127.0.0.1/item/queryItem.action?id=1](http://127.0.0.1/item/queryItem.action?id=1) 查询,GET
  2. [http://127.0.0.1/item/saveItem.action](http://127.0.0.1/item/saveItem.action) 新增,POST
  3. [http://127.0.0.1/item/updateItem.action](http://127.0.0.1/item/updateItem.action) 更新,POST
  4. [http://127.0.0.1/item/deleteItem.action?id=1](http://127.0.0.1/item/deleteItem.action?id=1) 删除,GET或POST

使用RestFul操作资源:可以通过不同的请求方式来实现不同的效果!如下:请求地址一样,但是功能可以不同

  1. [http://127.0.0.1/item/1](http://127.0.0.1/item/1) 查询,GET
  2. [http://127.0.0.1/item](http://127.0.0.1/item) 新增,POST
  3. [http://127.0.0.1/item](http://127.0.0.1/item) 更新,PUT
  4. [http://127.0.0.1/item/1](http://127.0.0.1/item/1) 删除,DELETE

学习测试:

  1. 新建一个类ControllerTest4
  1. @Controller
  2. public class ControllerTest4 {
  3. }
  1. 在SpringMVC中可以使用@Pathvariable注解,让方法参数的值对应绑定到一个URL模板变量上
  1. @Controller
  2. public class ControllerTest4 {
  3. //映射访问路径
  4. @RequestMapping("/commit/{p1}/{p2}")
  5. public String index(@PathVariable int p1, @PathVariable int p2, Model model){
  6. int result=p1+p2;
  7. //SpringMVC会自动实例化一个Model对象用于向视图中传值
  8. model.addAttribute("msg","结果:"+result);
  9. //返回视图位置
  10. return "hello";
  11. }
  12. }
  1. 测试:

SpringMVC学习笔记01 - 图16

  1. 思考:使用路径变量的好处
  • 使路径变得更加简洁
  • 获得参数更加方便,框架会自动进行类型转换
  • 通过路径变量的类型可以约束访问参数,如果类型不一样,则访问不到对应的请求方法,如这里访问的路径是/commit/1/a,则路径与方法不匹配,而不会是参数转换失败

SpringMVC学习笔记01 - 图17

  1. 修改一下对应的参数类型,再次测试
  1. @Controller
  2. public class ControllerTest4 {
  3. //映射访问路径
  4. @RequestMapping("/commit/{p1}/{p2}")
  5. public String index(@PathVariable int p1, @PathVariable String p2, Model model){
  6. String result=p1+p2;
  7. //SpringMVC会自动实例化一个Model对象用于向视图中传值
  8. model.addAttribute("msg","结果:"+result);
  9. //返回视图位置
  10. return "hello";
  11. }
  12. }

SpringMVC学习笔记01 - 图18

使用method属性指定请求类型

用于约束请求的类型,可以收窄请求范围。指定请求谓词的类型如GET 、POST、 HEAD 、OPTIONS 、PUT、 PATCH 、DELETE 、 TRACE等

测试:

  1. 增加一个方法
  1. //映射访问路径,必须是POST请求
  2. @RequestMapping(value="/hello",method={RequestMethod.POST})
  3. public String index2(Model model){
  4. model.addAttribute("msg","hello");
  5. return "hello";
  6. }
  1. 我们使用浏览器地址栏进行访问,默认是GET请求,会报错405:

SpringMVC学习笔记01 - 图19

  1. 如果将POST修改为GET则正常了
  1. //映射访问路径,必须是POST请求
  2. @RequestMapping(value="/hello",method={RequestMethod.GET})
  3. public String index2(Model model){
  4. model.addAttribute("msg","hello");
  5. return "hello";
  6. }
  7. }
  1. 使用浏览器进行访问

SpringMVC学习笔记01 - 图20

总结:

Spring MVC的@RequestMapping注解能够处理HTTP请求的方法,比如GET,PUT,POST,DELETE以及PATCH

所有的地址栏请求默认都会是HTTP GET类型

方法级别的注解变体有如下几个:组合注解

  1. @GetMapping
  2. @PostMapping
  3. @PutMapping
  4. @DeleteMapping
  5. @PatchMapping

@GetMapping是一个组合注解,平时使用的会比较多!

它所扮演的是@RequestMapping(method=RequestMethod.GET)的一个快捷方式