RequestMapping注解

  1. 1. @RequestMapping注解的功能
  2. 2. @RequestMapping注解的位置
  3. 3. @RequestMapping注解的value属性
    1. 3.1. 报错
    2. 3.2. 请求路径
  4. 4. method属性获取请求
  5. 5. params属性
  6. 6. RequestMapping注解的headers属性(了解)

@RequestMapping注解的功能

从注解名称上我们可以看到,@RequestMapping注解的作用就是将请求和处理请求的控制器方法关联
起来,建立映射关系。
SpringMVC 接收到指定的请求,就会来找到在映射关系中对应的控制器方法来处理这个请求。

@RequestMapping注解的位置

@RequestMapping标识一个类:设置映射请求的请求路径的初始信息
@RequestMapping标识一个方法:设置映射请求请求路径的具体信息

1
2
3
4
5
6
7
8
9
@Controller 
@RequestMapping("/test")
public class RequestMappingController {
//此时请求映射所映射的请求的请求路径为:/test/testRequestMapping
@RequestMapping("/testRequestMapping")
public String testRequestMapping(){
return "success";
}
}

@RequestMapping注解的value属性

@RequestMapping注解的value属性通过请求的请求地址匹配请求映射
@RequestMapping注解的value属性是一个字符串类型的数组,表示该请求映射能够匹配多个请求地址
所对应的请求
@RequestMapping注解的value属性必须设置,至少通过请求地址匹配请求映射

1
<a th:href="@{/testRequestMapping}">测试@RequestMapping的value属性-- >/testRequestMapping</a><br> <a th:href="@{/test}">测试@RequestMapping的value属性-->/test</a><br>
1
2
3
4
5
@RequestMapping( value = {"/testRequestMapping", "/test"} )
public String testRequestMapping()
{
return "success";
}

报错

There is already ‘requestMappingController’ bean method
两个相同路径报错
ctrl+t快速进入类

请求路径

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
package com.white.mvc.controller;

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

@Controller
//@RequestMapping("/hello")
//@RequestMapping注解的value属性通过请求的请求地址匹配请求映射
//@RequestMapping注解的value属性是一个字符串类型的数组,表示该请求映射能够匹配多个请求地址
public class RequestMappingController {

@RequestMapping(
value = {"/testRequestMapping", "/test"}
//匹配到一个就可以
)
public String index(){
System.out.println("success");
return "success";
}
}

method属性获取请求

post get请求

1
2
3
4
<a th:href="@{/test}">测试@RequestMapping的value属性-->/test
</a><br>
<form th:action="@{/test}" method="post"> <input type="submit">
</form>
  1. 对于处理指定请求方式的控制器方法,SpringMVC中提供了@RequestMapping的派生注解
    处理get请求的映射–>@GetMapping
    处理post请求的映射–>@PostMapping
    处理put请求的映射–>@PutMapping
    处理delete请求的映射–>@DeleteMapping
  2. 常用的请求方式有get,post,put,delete
    但是目前浏览器只支持get和post,若在form表单提交时,为method设置了其他请求方式的字符
    串(put或delete),则按照默认的请求方式get处理
    若要发送put和delete请求,则需要通过spring提供的过滤器HiddenHttpMethodFilter,在RESTful部分会讲到

    params属性

    @RequestMapping注解的params属性通过请求的请求参数匹配请求映射
    @RequestMapping注解的params属性是一个字符串类型的数组,可以通过四种表达式设置请求参数
    和请求映射的匹配关系
    “param”:要求请求映射所匹配的请求必须携带param请求参数
    “!param”:要求请求映射所匹配的请求必须不能携带param请求参数
    “param=value”:要求请求映射所匹配的请求必须携带param请求参数且param=value
    “param!=value”:要求请求映射所匹配的请求必须携带param请求参数但是param!=value
    1
    <a th:href="@{/testRequestMapping(username=123,password=123)}">测试params</a><br>
    ?可以用括号代替&以逗号隔开
    若当前请求满足@RequestMapping注解的value和method属性,但是不满足params属性,此时
    页面回报错400:Parameter conditions “username, password!=123456” not met for actual
    request parameters: username={admin}, password={123456}

    RequestMapping注解的headers属性(了解)

    @RequestMapping注解的headers属性通过请求的请求头信息匹配请求映射
    @RequestMapping注解的headers属性是一个字符串类型的数组,可以通过四种表达式设置请求头信
    息和请求映射的匹配关系
    “header”:要求请求映射所匹配的请求必须携带header请求头信息
    “!header”:要求请求映射所匹配的请求必须不能携带header请求头信息
    “header=value”:要求请求映射所匹配的请求必须携带header请求头信息且header=value
    “header!=value”:要求请求映射所匹配的请求必须携带header请求头信息且header!=value
    若当前请求满足@RequestMapping注解的value和method属性,但是不满足headers属性,此时页面
    显示404错误,即资源未找到