栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

@RequestMapping注解

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

@RequestMapping注解

目录

1.@RequestMapping注解的功能

2、@RequestMapping注解的位置

3、@RequestMapping注解的value属性

4、@RequestMapping注解的method属性

5、SpringMVC支持ant风格的路径

6. 用/传递参数 ,经常用于result风格的请求SpringMVC支持路径中的占位符(重点)原始方式:/deleteUser?id=1

7、@RequestMapping注解的params属性(了解)

8.@RequestMapping注解的headers属性(了解)

1.@RequestMapping注解的功能

从注解名称上我们可以看到,@RequestMapping注解的作用就是将请求和处理请求的控制器方法关联起来,建立映射关系。

SpringMVC 接收到指定的请求,就会来找到在映射关系中对应的控制器方法来处理这个请求。

2、@RequestMapping注解的位置

@RequestMapping标识一个类:设置映射请求的请求路径的初始信息  需要在请求中先有类的value再有方法的value

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

@Controller
@RequestMapping("/test")
public class RequestMappingController {

	//此时请求映射所映射的请求的请求路径为:http://localhost:8080/javaweb_4_15_2_war_exploded//test/testRequestMapping
    @RequestMapping("/testRequestMapping")
    public String testRequestMapping(){
        return "success";
    }

}

3、@RequestMapping注解的value属性

@RequestMapping注解的value属性通过请求的请求地址匹配请求映射

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

@RequestMapping注解的value属性必须设置,通过请求地址匹配请求映射

测试@RequestMapping的value属性-->/testRequestMapping
测试@RequestMapping的value属性-->/test
@RequestMapping(
        value = {"/testRequestMapping", "/test"}
)
public String testRequestMapping(){
    return "success";
}

两个a标签都可以成功跳转到success页面

4、@RequestMapping注解的method属性

在value匹配的基础上,请求方式也必须对应




    
    首页


首页
使用get发送请求
package com.hxut.rj1192.zyk;

import com.sun.org.apache.bcel.internal.generic.RETURN;
import com.sun.org.apache.regexp.internal.RE;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

@Controller
public class controller1 {
    @RequestMapping("/")
    public String print() {
        return "index";
    }

    @RequestMapping(value="/test_request_method",method = RequestMethod.POST)
    public String request_method()
    {
        return  "success";
    }
}

post请求可以访问,get请求报405

 

1、对于处理指定请求方式的控制器方法,SpringMVC中提供了@RequestMapping的派生注解

处理get请求的映射-->@GetMapping

处理post请求的映射-->@PostMapping

处理put请求的映射-->@PutMapping

处理delete请求的映射-->@DeleteMapping 

和使用RequestMapping是一样的,就是只能通过固定的请求方式来匹配

2.restful就是,就是同一个请求,访问相同的内容,但是用不同的请求方式区分不同的操作,具体看下面这个

restful_仰望星空的快乐的博客-CSDN博客

5、SpringMVC支持ant风格的路径

?:表示任意的单个字符

点我测试?  任意的单个字符
点我测试?  任意的单个字符,这个是两个字符,访问不了
   @RequestMapping(value="/te?t")
    public String test_wenhao()
    {
        return "success";
    }

*:表示任意的0个或多个字符

点我测试任意的多个或0个字符 ,这是0个,可以访问
点我测试任意的多个或0个字符,这是多个,可以访问
点我测试任意的多个或0个字符,这是1个,可以访问

 @RequestMapping(value = "/test*many")
    public String test_xing()
    {
        return  "success";
    }

**:表示任意的一层或多层目录,只要aa和  testxingxing能对上,不管**中写了什么,都可以访问

 @RequestMapping(value = "aatestxingxing")
    public String test_testxingxing()
    {
        return "success";
    }
点我测试任意的**,中间是一串数组字母,可以访问
这是中间随便写的路径,可以访问
这是中间为空,可以访问
这是后面不匹配,不能访问

6. 用/传递参数 ,经常用于result风格的请求
SpringMVC支持路径中的占位符(重点)
原始方式:/deleteUser?id=1

restful方式:/deleteUser/1

SpringMVC路径中的占位符常用于Restful风格中,当请求路径中将某些数据通过路径的方式传输到服务器中,就可以在相应的@RequestMapping注解的value属性中通过占位符{xxx}表示传输的数据,在通过@PathVariable注解,将占位符所表示的数据赋值给控制器方法的形参

@RequestMapping("/testRest/{id}/{username}")
public String testRest(@PathVariable("id") String id, @PathVariable("username") String username){
    System.out.println("id:"+id+",username:"+username);
    return "success";
}//最终输出的内容为-->id:1,username:admin
测试路径中的占位符-->/testRest

7、@RequestMapping注解的params属性(了解)

@RequestMapping注解的params   要求请求中必须带有或者不带有某个参数

@RequestMapping注解的params属性是一个字符串类型的数组,可以通过四种表达式设置请求参数和请求映射的匹配关系

"param":要求请求映射所匹配的请求必须携带param请求参数

"!param":要求请求映射所匹配的请求必须不能携带param请求参数

"param=value":要求请求映射所匹配的请求必须携带param请求参数且param=value

"param!=value":要求请求映射所匹配的请求必须携带param请求参数但是param!=value

测试@RequestMapping的params属性-->/test
@RequestMapping(
        value = {"/testRequestMapping", "/test"}
        ,method = {RequestMethod.GET, RequestMethod.POST}
        ,params = {"username","password!=123456"}
)
public String testRequestMapping(){
    return "success";
}

注:

若当前请求满足@RequestMapping注解的value和method属性,但是不满足params属性,此时页面回报错400:Parameter conditions "username, password!=123456" not met for actual request parameters: username={admin}, password={123456}

8.@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错误,即资源未找到

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/871878.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号