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. css随堂笔记(二)

    css   sub注释 注释不能嵌套 sub生成结构代码快捷 复合选择器 1.后代选择器 语法:选择器1 选择器2 选择器3  { 属性名:属性值 } 2.子代选择器 子代选择器语法: 选择器1> ...

  2. (开发)ESLint - 代码规范

    参考文档:http://eslint.cn/ ESLint 是在 ECMAScript/JavaScript 代码中识别和报告模式匹配的工具,它的目标是保证代码的一致性和避免错误.在许多方面,它和 J ...

  3. pm2的的常用命令及用法

    使用pm2启动静态文件服务器的方法如下: pm2 serve path port pm2 serve . 9001 这样就可以把当前文件夹下的静态文件跑起来了,而且端口号是9001, 同样也支持进阶的 ...

  4. (四)JavaScript之[break和continue]与[typeof、null、undefined]

    7].break和continue /** * JavaScript 的break和continue语句 * break 跳出switch()语句 * break 用于跳出循环 * continue ...

  5. SharePoint 栏的三种名字Filed :StaticName、 InternalName、 DisplayName

    SharePoint 的栏,有3个名字, StaticName InternalName  DisplayName. 当在第一次创建栏的时候,这3个名字一起进行创建,并且都一样. <FIELD  ...

  6. 通过windows计划任务和Dos批处理备份文件

    目的: 1.计划每天每半小时备份1次,每天8点开始,执行12小时,20点结束. 2.定期删除历史备份文件,由于每天有多个时间段备份,删除前只保留当天最后一个备份. 说明: 由于删除的操作只有每天第一次 ...

  7. 1929. Teddybears are not for Everyone (Timus) (combination+reading questions)

    http://acm.timus.ru/problem.aspx?space=1&num=1929 combination problems. 排列组合问题. According to the ...

  8. des的根据key进行加密和解密方法

    DES加密: public static string DESEncode(string content, string key) { DESCryptoServiceProvider des = n ...

  9. selenium项目--读取测试用例

    读取测试用例 一直我们都没有考虑过读取测试用例的事,我们现在这样设计测试用例有两个好的点,在执行方法时,打印测试用例,方便知道执行的内容是什么,在报告展示时,把测试用例的结果展示出来 实现方案:目前我 ...

  10. 简单的Nodejs模块

    说千遍,道万遍,不如动手做一遍,我们实现一个node所谓的模块 看下上面的图,了解一下模块自始至终的一个流程,首先是创建模块,也就是一个入口的js文件,里面加了一些特定的功能,然后导出这个模块, ex ...