详解Spring Boot接收参数的19种方式
SpringBoot接受参数相关
@PathVariable注解
使用场景:解析占位变量
url:/monster/{id}/{name} —> /monster/king/100
与@RequestParam的区别是没有参数名
/**
* /monster/{id}/{name} 解读
* 1. /monster/{id}/{name} 构成完整请求路径
* 2. {id} {name} 就是占位变量
* 3. @PathVariable("name"): 这里name 和{name} 命名保持一致,与注解内的name一致
* 4. String name_ 这里自定义,老师故意这样写下
* 5. @PathVariable Map<String, String> map 把所有传递的值传入map
* map = {name=king, id=100}
* 6. 可以看下@PathVariable源码
*/
@GetMapping("/monster/{name}/{id}")
public String pathVariable(@PathVariable("name")String name_,
@PathVariable("id")Integer id, @PathVariable Map<String,String> map){
System.out.println("name = " + name);
System.out.println("id = " + id);
System.out.println("map = " + map);
return "success";
}@RequestHeader注解
使用场景:解析请求头信息
/**
*
* 解读:
* 1.@RequestHeader获取请求头信息
* 2,@RequestHeader("Host") String host:获取请求头host的信息
* 2.1 @RequestHeader("Host"),@RequestHeader中的value值大小写无差别
* 2.2 String host:名字程序员自定义
* 3.@RequestHeader Map<String,String> header:获取到http请求头的所有信息
* @param host
* @param header
* @return
*/
@RequestMapping("/requestHeader")
public String requestHeader(@RequestHeader("Host") String host,
@RequestHeader Map<String,String> header){
System.out.println("host = " + host);
System.out.println("header = " + header);
return "success";
}@RequestParam注解
使用场景:获取请求参数信息
/**
*
* 内容:@RequestParam:获取请求参数
* 解读:
* 1.@RequestParam(value = "name",required = true) String username
* 1.1 @RequestParam(value = "name":获取参数名为name的值
* 1.2 required = true,不允许不传入该属性的值,即可以不填写该属性会报错
* required = false,即使没有传入该属性,也不会报错,值为null
* 2.@RequestParam("fruit")List<String>fruits:当一个属性有多个值的时候用List数组接收
* 3.@RequestParam Map<String,String> paras:可以用Map集合接收所有数据
* 注意:这样写有一个小问题,当一个值为数组类型(有多个数据的时候),只能接收第一个数据
* 原因:因为Map的泛型为<String,String>,获取的值是唯一的,不能接收数组或集合类型
* @param username
* @param fruits
* @return
*/
@RequestMapping("/requestParam")
public String requestParam(@RequestParam(value = "name",required = true) String username,
@RequestParam("fruit")List<String>fruits,
@RequestParam Map<String,String> paras){
System.out.println("username = " + username);
System.out.println("fruits = " + fruits);
System.out.println("paras = " + paras);
return "success";
}SpringMVC自动封装参数对象
/**
* 将获取到的数据封装成对象
* 解读:
* 1.方法的形参用对应的类型来指定即可,SpringMVC会自动进行封装
* 2.如果是自动完成封装,则需要提交的数据-参数名与对象的字段名保持一致
* 3.如果属性是对象,我们通过字段名.字段名的方式提交数据
* 例如Master[pet],提交的数据名应该是 pet.id,pet.name等等【级联操作】
* 4.如果提交数据的参数名和对象的字段名不匹配,则对象的属性值为null
*/
@RequestMapping("/vote03")
public String getPojoObject(Master master){
System.out.println("master = " + master);
return "success";
}@RequestBody
使用场景:前端传来的是json数据
/**
* 1.@RequestBody User user在形参制定了@RequestBody注解
* 2.springmvc就会将交提交的json字符串数据转换成指定的javabean
* 3.注意:前后端的属性值应该匹配,否则会返回空
* 4.如果没有@RequestBody修饰,该属性的前后端的值都为空。
* @param user
* @return
*/
@ResponseBody
@RequestMapping("json/user")
public User UserHandler(@RequestBody User user) {
//接收前台传入的json数据,并以json的格式传回浏览器
System.out.println("user = " + user);
return user;
}@CookieValue
使用场景:获取cookie数据
/**
* 内容:获取cookie数据
* 解读:
* 1.配置环境:我们在浏览器自己添加cookie,右键检查,在存储中添加(也可能在application)
* 2.@CookieValue(value = "cookie_key",required = false) String cookie_value
* 2.1 获取名字为cookie_key的Cookie的value值
* 2.2 String cookie_value,如果注解修饰的类型为String,则获取的是Cookie对应的value值
* 3.@CookieValue(value = "username",required = false)Cookie userCookie)
* 3.1 获取名字为username的Cookie对象
* 3.2 Cookie userCookie,如果注解修饰的类型为Cookie,则获取的是Cookie对象
* 4.required = false:参数是否必须传入,同@RequestParam
* 5.也可以通过HttpServletRequest获取cookie
* @param cookie_value
* @param userCookie
* @return
*/
@RequestMapping("/cookieValue")
public String cookieValue(@CookieValue(value = "cookie_key",required = false) String cookie_value,
@CookieValue(value = "username",required = false)Cookie userCookie,
HttpServletRequest request){
System.out.println("cookie_value = " + cookie_value);
System.out.println("userCookie = " + userCookie);
System.out.println("userCookie.getName() = " + userCookie.getName());
System.out.println("userCookie.getValue() = " + userCookie.getValue());
Cookie[] cookies = request.getCookies();
for (Cookie cookie : cookies) {
System.out.println("cookie = " + cookie);
}
return "success";
}级联操作
应用场景:对象的属性是另一个对象的实例
/**
* 将获取到的数据封装成对象
* 解读:
* 1.方法的形参用对应的类型来指定即可,SpringMVC会自动进行封装
* 2.如果是自动完成封装,则需要提交的数据-参数名与对象的字段名保持一致
* 3.如果属性是对象,我们通过字段名.字段名的方式提交数据
* 例如Master[pet],提交的数据名应该是 pet.id,pet.name等等【级联操作】
* 4.如果提交数据的参数名和对象的字段名不匹配,则对象的属性值为null
*/
@RequestMapping("/vote03")
public String getPojoObject(Master master){
System.out.println("master = " + master);
return "success";
}到此这篇关于Spring Boot接收参数的19种方式的文章就介绍到这了,更多相关Spring Boot接收参数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
springboot3整合knife4j详细图文教程(swagger增强)
开发api提供对应的接口规范进行联调或并行开发,api文档管理必不可少,常用的Knife4j基于swagger(依赖已经compile),可以进行管理,下面这篇文章主要给大家介绍了关于springboot3整合knife4j的相关资料,需要的朋友可以参考下2024-03-03
SpringBoot使用Sa-Token实现账号封禁、分类封禁、阶梯封禁的示例代码
本文主要介绍了SpringBoot使用Sa-Token实现账号封禁、分类封禁、阶梯封禁的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2023-07-07
springboot新建项目pom.xml文件第一行报错的解决
这篇文章主要介绍了springboot新建项目pom.xml文件第一行报错的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-01-01
SpringBoot的@EnableAsync和@Async注解分析
这篇文章主要介绍了SpringBoot的@EnableAsync和@Async注解分析,Spring Boot是一个快速开发框架,可以帮助开发人员快速构建基于Spring的应用程序,需要的朋友可以参考下2023-07-07
解决程序包org.springframework.test.context不存在
这篇文章主要介绍了解决程序包org.springframework.test.context不存在的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-09-09


最新评论