首页 > 其他分享 >SpringMVC:@RequestMapping注解

SpringMVC:@RequestMapping注解

时间:2024-06-01 16:31:10浏览次数:24  
标签:RequestMapping SpringMVC value Referer params 注解 password 请求

1. @RequestMapping作用

@RequestMapping` 注解是 Spring MVC 框架中的一个控制器映射注解,用于将请求映射到相应的处理方法上。具体来说,它可以将指定 URL 的请求绑定到一个特定的方法或类上,从而实现对请求的处理和响应。

2.  出现位置的区别

出现在类上

//@RequestMapping注解:放类上时所有方法都在该路径上
//当访问资源含有/user时会访问该类,匹配相对应要执行的函数
//如:访问下面/detail资源时实际访问路径为/user/detail
@RequestMapping(value = "/user")
public class UserController {

出现在方法上

//注解在方法上时当访问资源路径中有/user/detail时会执行下面的方法
    @RequestMapping(value = "/detail")
    public String detail() {
        //返回的字符串即要访问的资源(返回逻辑视图)
        return "userdetail";
    }

3. @RequestMapping注解的value属性 

value属性用于设置请求资源路径

value值的使用 

/***
 * 细节一:
 * 一个资源可以对应多个路径(即同一个终点(资源)可以通过不同的方法去访问)
 * 但一个路径不能同时对应多个终点(资源)
 */

返回的逻辑视图为要展示的资源,后端通过该逻辑视图找到对应资源进行展示

 //一个资源被多个路径对应
    //当数组只有一个数据时大括号可以省略即上面的写法
    //当value值只要一个value也可也省略
    //value也可以被path替换,底层中path是value的别名
    @RequestMapping(value = {"/detail2", "detail3"})
    public String detail2() {
        return "userdetail";
    }

Ant风格的value值 

 

/***
 * 细节二:Ant风格的value值
 * ant风格的value值模糊匹配
 *       ?,代表任意一个字符(除 / 或者 ? 之外的任意字符) 一定是字符,空着也不行
 *              如:@RequestMapping(value = "/ant/a?t")
 *       *,代表0到N个任意字符 (除了 / 或者 ? 之外的任意n个字符)
 *       **,代表0到N个任意字符,并且路径中可以出现路径分隔符 /
 *
 * 注意:** 通配符在使用时,左右不能出现字符,只能是 /
 * spring6之后用**进行模糊匹配时必须是结尾,否则只有一个*的效果
 */
@RequestMapping(value = {"/ant/a?t", "/ant/a*t", "/ant/**"})
    public void testAnt() {

    }

占位符

/***
 * 细节三:占位符
 *普通的请求路径:http://localhost:8080/springmvc/login?username=admin&password=123&age=20
 * RESTful风格的请求路径:http://localhost:8080/springmvc/login/admin/123/20
 */
//此时id和password充当占位符,可接收id和password的值
    @RequestMapping("/testURL/{id}/{password}")
    public String testURL(
            //用注解@PathVariable可将占位符的值赋给下面的变量
            @PathVariable("id")
            String id,
            @PathVariable("password")
            String password) {
        System.out.println("id:" + id + " password:" + password);
        return "ok";
    }

4. @RequestMapping注解的method属性

method属性用于设置前端请求方式 

//设置method属性则限制前端的请求方式
    //即前端必须以post方式请求才能访问该资源,否则会报405错误
    @RequestMapping(value = "/method", method = RequestMethod.POST)
    public String tetMethod() {
        return "ok";
    }

衍生注解

/***
 * 衍生注解
 *  @PostMapping 等同于 @RequestMapping(value =" ", method = RequestMethod.POST)
 *  @GetMapping  等同于 @RequestMapping(value =" ", method = RequestMethod.GET)
 *  @PatchMapping
 */

 常用提交方式

/***
 * 常用提交方式:
 * post get put delete head
 * post:适合新增
 * get:适合查询
 * delete:适合删除
 * head:适合返回一些头部信息,不包含响应体
 * form表单提交只有get和post两种方式
 * 若要其他方式需用axios
 */

 5. @RequestMapping设置请求参数

 params属性的理解

params属性用来设置通过请求参数来映射请求。对于RequestMapping注解来说:

* value属性是一个数组,只要满足数组中的任意一个路径,就能映射成功
* method属性也是一个数组,只要满足数组中任意一个请求方式,就能映射成功。
* **params属性也是一个数组,不过要求请求参数必须和params数组中要求的所有参数完全一致后,才能映射成功。

 四种用法

 //设置params参数后请求路径必须携带params设置的参数,不然会报400错误即请求参数不一致
    @RequestMapping(value = "/params", params = {"username", "password"})

    //此时携带的参数中username的值必须为zhangsan,否则也是请求参数不一致
    @RequestMapping(value = "/params", params = {"username=zhangsan", "password"})

    //即携带参数不能含有username  写法:params = {"!username"}
    @RequestMapping(value = "/params", params = {"!username"})
    
    //携带参数中username的值不能为zhangsan
    @RequestMapping(value = "/params", params = {"username!='zhangsan", "password"})
    public String testParams() {
        return "ok";
    }

 测试用例

<a th:href="@{/user/params(username='zhangsan', password=1234)}">参数页面</a>

 6. @RequestMapping设置请求头

headers和params原理相同,用法也相同。当前端提交的请求头信息和后端要求的请求头信息一致时,才能映射成功。 

四种用法 

@RequestMapping(value="/login", headers={"Referer", "Host"}) 表示:请求头信息中必须包含Referer和Host,才能与当前标注的方法进行映射。

@RequestMapping(value="/login", headers={"Referer", "!Host"}) 表示:请求头信息中必须包含Referer,但不包含Host,才能与当前标注的方法进行映射。

@RequestMapping(value="/login", headers={"Referer=http://localhost:8080/springmvc/", "Host"}) 表示:请求头信息中必须包含Referer和Host,并且Referer的值必须是http://localhost:8080/springmvc/,才能与当前标注的方法进行映射。

@RequestMapping(value="/login", headers={"Referer!=http://localhost:8080/springmvc/", "Host"}) 表示:请求头信息中必须包含Referer和Host,并且Referer的值不是http://localhost:8080/springmvc/,才能与当前标注的方法进行映射。 

标签:RequestMapping,SpringMVC,value,Referer,params,注解,password,请求
From: https://blog.csdn.net/2301_79526467/article/details/139369898

相关文章

  • 使用Spring Boot自定义注解 + AOP实现基于IP的接口限流和黑白名单
    ......
  • 零基础学Java第二十四天之注解的理解与使用
    注解1、什么是注解java.annotation包Annotation是从JDK1.5开始引入的新技术,注解即可以对程序员解释又可以对程序解释2、注解与注释的区别注释:对程序员解释代码信息注解:对程序和程序员解释代码信息3、注解的所用不是程序本身,可以对程序作出解释(与注释(comment)类......
  • Spring的@Async注解及其用途
    Spring的@Async注解是SpringFramework4.2版本引入的功能,它用于支持异步方法执行。当一个方法标注了@Async,Spring会在一个单独的线程中调用该方法,从而不会阻塞主线程的执行。@Async注解的用途:提高性能:通过异步执行,可以提高应用程序的响应性能,特别是在执行耗时的......
  • spring:十、springMVC拦截器
    目录包结构坐标引入mvc配置文件springmvc.xmlweb.xml配置控制器拦截器多拦截器执行顺序:包结构坐标引入<dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>3.......
  • spring:九、springmvc响应
    资源解析器(springmvc.xml)<!--内部资源视图解析器--><beanid="defaultViewResolver"class="org.springframework.web.servlet.view.InternalResourceViewResolver"><propertyname="prefix"value="/WEB-INF/page/......
  • springboot关键注解
    目录标记容器类注解1.@Controller 2.@Service3.@Repository4.@Component 依赖注入注解1.@Autowired2.@Resource@Autowired与@Resource的区别 web相关注解@RequestMapping属性介绍用法示例注意事项@GetMapping和@PostMapping @RestController......
  • java 注解和反射
    8.注解和反射8.1什么是注解annotationjkd5.0提供的8.2内置注解:@override覆盖方法@Deprecated不推荐使用,@suppressWarnings抑制警告信息:8.3元注解:解释其他注解的注解meta-annotation@Target描述注解范围@Retention注解生命周期:source<class<runtime@Documented:注......
  • @Transactional(rollbackFor = Exception.class) 事务失效 A加了@Transactional注解
    @Transactional(rollbackFor=Exception.class)事务失效,一个方法A上加了这个注解,在方法A中调用了B方法,A方法中有数据库操作,B方法中也有,现在问题是,B方法中事务失效了,怎么保证不失效 在Spring框架中,使用@Transactional注解可以很方便地管理事务,但是如果你在方法A中调用了方法B,......
  • springmvc和springboot有什么区别?
    springmvc和springboot有什么区别?SpringMVC和SpringBoot是两个与Java开发相关的框架/工具,它们在JavaWeb应用程序开发中有着不同的作用和优势。SpringMVC:定位:SpringMVC是一种基于Java的Web框架,用于构建Web应用程序的控制器层。功能:它提供了一个模型-......
  • @PostConstruct 注解方法 mybatis-plus分页插件 PageHelper失效
    需求:启动项目把某些高频搜索的数据,放入到缓存中;现象:利用@PostConstruct项目启动加载,但是并没有做到分页,而是降所有数据放入的redis中,出现问题 @PostConstruct注解方法mybatis-plus分页插件PageHelper失效@PostConstructpublicvoidinit(){longkeyStartTime......