pringMVC通过使用@RequestMapping注解,实现指定控制器可以处理哪些URL请求。

控制器的类定义及方法定义处都可以标注@RequestMapping:

  • 类定义处:提供初步的请求映射信息。相对于WEB 应用的根目录。
  • 方法定义处:提供进一步的细分映射信息。相对于类定义处的URL。若类定义处未标注@RequestMapping,则方法处标记的URL 相对于WEB 应用的根目录。

      下面测试一下,当我们仅在方法hello()处添加注解@RequestMapping(“/helloworld”)时,通过页面超链接地址”helloworld”可以正常跳转到success.jsp页面:

现在我们添加类定义处的注解@RequestMapping(“/hello”):

那么通过上面的超链接地址”helloworld”访问则会提示:

必须将超链接地址改为”hello/helloworld”,才可以正常跳转:

类定义处标记的@RequestMapping(“/hello”)限定了处理器类可以处理所有URL为/hello的请求,它相对于WEB容器部署的根路径;而通过在方法处标记@RequestMapping注解,则可以实现让处理器类定义多个处理方法,以处理来自/hello下的不同请求。

@RequestMapping除了可以使用请求URL映射请求外,还可以使用请求方法、请求参数及请求头映射请求

标准的HTTP请求报头格式如下:

@RequestMapping的value、method、params及headers 分别表示请求URL、请求方法、请求参数及请求头的映射条件,他们之间是与的关系,联合使用多个条件可让请求映射更加精确化(params和headers不常用,了解即可)。method指定请求方式为GET或是POST,params的表达式格式如下:(headers与其类似)

  • param1: 表示请求必须包含名为param1 的请求参数。
  • !param1: 表示请求不能包含名为param1 的请求参数。
  • param1 != value1: 表示请求包含名为param1 的请求参数,但其值不能为value1。
  • {“param1=value1”, “param2”}: 请求必须包含名为param1 和param2 的两个请求参数,且param1参数的值必须为value1。

那么比如我们现在可以将hello()方法注解为:

 即该方法只会处理请求路径为”hello/helloworld”,请求方法为GET,必须带有参数userId和age,其中age值不能为10,且请求头中Accept-Language要为zh-CN,zh;q=0.8的请求。

@RequestMapping映射的url还可以使用Ant风格的通配符

?:匹配文件名中的一个字符 
*:匹配文件名中的任意字符 
**:匹配多层路径

  例如,/user/*/createUser: 可以匹配 /user/aaa/createUser、/user/bbb/createUser等URL

@PathVariable可以映射URL绑定的占位符

  带占位符的URL 是Spring3.0 新增的功能,该功能在SpringMVC向REST目标挺进发展过程中具有里程碑的意义。通过@PathVariable可以将URL 中占位符参数绑定到控制器处理方法的参数中:URL 中的{xxx} 占位符可以通 过@PathVariable(“xxx”) 绑定到操作方法的入参中,注意两个“xxx”必须一致。例如,我们可以将方法hello()注解为:

那么,当我们在页面中的请求格式为:

则可以在方法中获取id值为5,并输出到控制台。

表现层状态转化REST(Representational State Transfer)

REST是目前最流行的一种互联网软件架构。它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用。解释一下名词: 
  资源(Resources):网络上的一个实体,或者说是网络上的一个具体信息。它可以是一段文本、一张图片、一首歌曲、一种服务,总之就是一个具体的存在。可以用一个URL(统一资源定位符)指向它,每种资源对应一个特定的URL。要获取这个资源,访问它的URL就可以,因此URL 即为每一个资源的独一无二的识别符。 
  表现层(Representation):把资源具体呈现出来的形式,叫做它的表现层(Representation)。比如,文本可以用txt 格式表现,也可以用HTML 格式、XML 格式、JSON 格式表现,甚至可以采用二进制格式。 
  状态转化(State Transfer):每发出一个请求,就代表了客户端和服务器的一次交互过程。HTTP协议,是一个无状态协议,即所有的状态都保存在服务器端。因此,如果客户端想要操作服务器,必须通过某种手段,让服务器端发生“状态转化”(State Transfer)。而这种转化是建立在表现层之上的,所以就是“表现层状态转化”。具体说,就是HTTP 协议里面,四个表示操作方式的动词:GET、POST、PUT、DELETE。它们分别对应四种基本操作:GET 用来获取资源,POST 用来新建资源,PUT 用来更新资源,DELETE 用来删除资源。 
  示例: 
  – /order/1 HTTP GET:得到id= 1 的order 
  – /order/1 HTTP DELETE:删除id = 1的order 
  – /order/1 HTTP PUT:更新id = 1的order 
  – /order HTTP POST:新增order 
   
  但是,浏览器form 表单只支持GET与POST请求,不支持DELETE和PUT 。Spring3.0 添加了一个过滤器HiddenHttpMethodFilter,它可以将DELETE和PUT请求转换为标准的http 方法,使得支持GET、POST、PUT 与DELETE 请求。(查看源码我们知道了HiddenHttpMethodFilter工作原理是当页面发送一个POST请求时,同时发送一个隐藏域_method,根据_method值为DELETE或者PUT,过滤器HiddenHttpMethodFilter封装一个新的请求传给SpringMVC) 
  下面以DELETE请求为例,首先在web.xml中配置HiddenHttpMethodFilter:

<!-- 配置 org.springframework.web.filter.HiddenHttpMethodFilter: 可以把 POST
请求转为 DELETE 或 PUT 请求 -->
<filter>
<filter-name>HiddenHttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter> <filter-mapping>
<filter-name>HiddenHttpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

将控制器中的方法限定为只处理请求方法为DELETE的请求:

@Controller
@RequestMapping("/hello")
public class Hello { @RequestMapping(value = "/helloworld/{id}", method = RequestMethod.DELETE)
public String hello(@PathVariable("id") Integer id) {
System.out.println("Test DELETE, id = " + id);
return "success";
}
}

页面中的form表单为:

   <form action="hello/helloworld/5" method="post">
<input type="hidden" name="_method" value="DELETE">
<input type="submit" value="Test REST DELETE">
</form>

测试:

成功跳转:

控制台正确输出:

注:以上内容参考自佟刚老师的Spring MVC视频教程。 

SpringMVC使用注解@RequestMapping映射请求的更多相关文章

  1. SpringMVC之使用 @RequestMapping 映射请求

    @RequestMapping注解 SpringMVC使用该注解让控制器知道可以处理哪些请求路径的,除了可以修饰方法,还可以修饰在类上. – 类定义处:提供初步的请求映射信息.相对于 WEB 应用的根 ...

  2. SpringMVC之使用requestMapping映射请求、映射参数、映射头

    1. 映射请求 作用:使用requestMapping可以指定处理器可以处理那些请求 地方:类和方法前面都可以 @requestMapping 类定义处: 提供初步的请求映射信息,相对于web应用的根 ...

  3. SpringMVC学习 -- 使用 @RequestMapping 映射请求

    在控制器的类定义及方法出定义出都可以标注 @RequestMapping: 类定义处:提供初步的请求映射信息.相对于 Web 应用的根目录. 方法定义出:提供进一步的细分映射信息.相对于类定义处的 U ...

  4. SpringMVC听课笔记(三:使用@RequestMapping映射请求)

    1. Spring MVC使用 @RequestMapping 注解为控制器指定可以处理哪些URL请求 2. 标注点: --类定义处:提供初步的请求映射信息.相对于WEB应用的根目录 --方法处:提供 ...

  5. @RequestMapping映射请求,@PathVariable,@RequestParam,@RequestHeader的使用

    1.@RequestMapping Spring MVC 使用 @RequestMapping 注解为控制器指定可以处理哪些 URL 请求,在控制器的类定义及方法定义处都可标注. @RequestMa ...

  6. 用@RequestMapping映射请求

    DispatcherServlet接受一个web请求之后,将请求发送给@Controller注解声明的不同控制器类. 这个调度过程依赖控制器类及其处理程序方法中声明的各种@RequestMapping ...

  7. @RequestMapping映射请求

     1.SpringMVC使用@RequestMapping注解为控制器指定可以处理哪些URL请求.   2.在控制器的类定义和方法定义处都可标注@RequestMapping   2.1 类定义处:提 ...

  8. 获取SpringMVC中所有RequestMapping映射URL信息

    SpringMVC启动的时候,会把接口信息收集在RequestMappingHandlerMapping中,故可以通过这个类,拿到全部的映射信息,Sample代码段如下: @Autowired pri ...

  9. 使用 @RequestMapping 映射请求

随机推荐

  1. iOS重用宏定义

    iOS 多快好省的宏(转) 原文地址:http://my.oschina.net/yongbin45/blog/150149 // 字符串: #ifndef nilToEmpty #define ni ...

  2. vue安装--使用node

    总结: # 全局安装 vue-cli $ npm install --global vue-cli # 创建一个基于 webpack 模板的新项目 $ vue init webpack my-proj ...

  3. iDempiere 使用指南 生产插件(Manufacturing)安装过程

    Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/ iDempiere官方中文wiki主页 http://wiki.idemp ...

  4. Android基础Activity篇——销毁活动

    销毁活动只需要添加 finish(); 这个方法即可.相当于back键.

  5. 在 eclipse 中调出其内置的浏览器

    两种方法: 1.点击工具栏中的浏览器图标,就会在主面板中出现浏览器: 跳出一个blank页面,如下: 第二种方法:点击Window——Show view——Other 输入 "browser ...

  6. SaberSama【css总结】

    为什么要转过来呢? 因为我觉到,同样是一个初学者,应该互相学习,交流. css:Cascading Style Sheets 层叠样式表 CSS引入方式: 1.内嵌: <p style=&quo ...

  7. Html5 web本地存储

    Web Storage是HTML5引入的一个非常重要的功能,可以在客户端本地存储数据,类似HTML4的cookie,但可实现功能要比cookie强大的多,cookie大小被限制在4KB,Web Sto ...

  8. 2017.10.21 Java中的数据源与连接池技术

    1.数据源技术就是预先建立好一定的数量的数据库连接,并将这些连接保存在连接池中,有连接池负责对这些数据库连接管理,当访问数据库时,只需要从连接池中取出有空闲状态的数据库连接:当程序访问数据库结束时,释 ...

  9. CUDA三维数组

    http://hpcbbs.it168.com/forum.php?mod=viewthread&tid=1643 根据上面链接的帖子研究了下三维数组,就像他自己说的一样是有问题的,我自己修改 ...

  10. git常用命令图解