@PathVariable

作用:@PathVariable是spring3.0的一个新功能:接收请求路径中占位符的值,将URL中占位符参数{xxx}绑定到处理器类的方法形参中@PathVariable(“xxx“)

 @GetMapping("/car/{id}/owner/{username}")
public Map<String,Object> getCar(@PathVariable("id") Integer id,
@PathVariable("username") String name,
) {
Map<String,Object> map = new HashMap<>();
map.put("id",id);
map.put("name",name);
return map;
}

请求参数示例:http://localhost:8080/car/2/owner/birdy

上面的例子有多个占位符,形参列表需要定义多个参数,不是很方便,可以直接定义一个map集合 @PathVariable Map<String,String> kv,会自动映射多个参数

@GetMapping("/car/{id}/owner/{username}")
public Map<String,Object> getCar( @PathVariable Map<String,String> kv) {
Map<String,Object> map = new HashMap<>();
String id = kv.get("id");
String name = kv.get("username");
map.put("id",id);
map.put("name",name);
return map;
}

@RequestParam

@RequestParam主要用于将请求参数区域的数据映射到控制层方法的参数上

语法:

@RequestParam(value=”参数名”,required=”true/false”,defaultValue=””)
  • value:请求中传入参数的名称,即前端传过来时定义的参数名。如果不设置value值,

    则前端定义的参数名必须和后端接口参数名相同
  • required:该参数是否为必传项。默认是true,表示请求中一定要传入对应的参数,否则会报404错误;如果设置为false,当请求中没有此参数,将会默认为null。而对于基本数据类型的变量,则必须有值,这时会抛出空指针异常。如果允许空值,则接口中变量需要使用包装类来声明。
  • defaultValue:参数的默认值,如果请求中没有同名的参数时,该变量默认为此值。注意默认值可以使用SpEL表达式,如"#{systemProperties['java.vm.version']}"
 @GetMapping("/user")
public Map<String,Object> getUser(@RequestParam("age") Integer age,
@RequestParam("inters") List<String> inters,
) {
Map<String, Object> map = new HashMap<>();
map.put("age",age);
map.put("inters",inters);
return map;
}
请求示例:http://localhost:8080/user?age=18&inters=game&inters=music
返回结果:{"inters":["game","music"],"age":18}

@RequestParam同样可以定义集合类型参数 @RequestParam Map<String,String> params来映射多个参数

@RequestBody

作用:@RequestBody主要用来接收前端传递给后端的json字符串中的数据的(请求体中的数据的)

注意点:

  • GET方式无请求体,所以使用@RequestBody接收数据时,前端不能使用GET方式提交数据,而是用POST方式进行提交
  • 在后端的同一个接收方法里,@RequestBody与@RequestParam()可以同时使用,@RequestBody最多只能有一个,而@RequestParam()可以有多个
  • 如果参数时放在请求体application/json传入后台的话,那么后台要用@RequestBody才能接收到
  • 如果不是放在请求体中的话,那么后台接收前台传过来的参数时,要用@RequestParam来接收,或者形参前 什么也不写也能接收

在实际的工作需求中,写接口的人会经常遇到对于Bean各种各样的操作,比如我对数据库要写个Bean,返回前台还得有个Vo bean,在另一个需求又用到和这个类似的Bean了,但是就有些字段不一样啊,字段的有些类型不一样啊,接收的参数名不一样啊,反正就是一个小小的需求变动,可能就需要写好几个不同的Bean,之前需求没那么多的时候写两个就写两个吧,后来写的多了就烦了,所以认真研究下怎么转换就迫在眉睫了。

@JsonAlias

作用是在反序列化的时候可以让Bean的属性接收多个json字段的名称。可以加在字段上或者getter和setter方法上。

@Data
public class User implements Serializable{
@JsonAlias({"name","user"})
private String username;
private String password;
private Integer age;
}

实体类需要有get和set方法

@PostMapping("/user")
public User getUserIfo(@RequestBody User user){
return user;
}

路径http://localhost:8080/user

//入参
{
“name” : “小明”,
“password” : “123”,
"age" : 15
}

可以从下面看到json字段是name也成功对应到了Bean的username属性 ,但是字段名没变

//postman返回结果
{
"username": "birdy",
"password": "123",
"age": 18
}

@JsonProperty

  • 向流中写入对象的操作 称为 序列化

  • 从流中读取对象的操作 成为 反序列化

这个注解是更改Bean字段的属性名用的。

  • access:是更改逻辑属性序列化和反序列化的可见性,

Access.WRITE_ONLY:只在序列化时使用修改后的字段

Access.READ_ONLY:只在反序列化时使用,类似于@JsonAlias注解

Access.READ_WRITE:在序列化和反序列化都使用修改后字段

Access.AUTO:自动确定,一般是和第三个一样,啥情况不一样我也不清楚,如果不写access,默认就是这个。

value是逻辑属性的名称,如果只有value则省略

  • value::更改后的属性名

示例

@Data
public class User implements Serializable {
//只在序列化写入操作时使用该属性名
@JsonProperty(value = "name", access = JsonProperty.Access.WRITE_ONLY)
private String username;
private String password;
private Integer age;
}
@PostMapping("/user")
public User getUserIfo(@RequestBody User user){
System.out.println(user.toString());
return user;
}

入参:

{
"name" : "birdy",
"password" : "123",
"age" : 18
}

结果:

//console
User(username=birdy, password=123, age=18)
//postman没有获取到name属性
{
"password": "123",
"age": 18
}

查看源码

Access setting that means that the property may only be written (set)
as part of deserialization (using "setter" method, or assigning to Field

表示只有在写入时调用属性的set方法才会用该属性名

猜猜若改成@JsonProperty(value = "name", access = JsonProperty.Access.READ_ONLY)会怎样?

//控制台
User(username=null, password=123, age=18)
//postman
{
"password": "123",
"age": 18,
"name": null
}

由于写入时无法调用set方法赋值,所以控制台打印该属性时没有值;但是返回结果已经可以调用修改后的属性get方法,所以username属性已经被修改为name,只是没有值

若是access = JsonProperty.Access.AUTO

//控制台
User(username=birdy, password=123, age=18)
//postman
{
"password": "123",
"age": 18,
"name": birdy
}

可以看到控制台打印的属性名称都没有变,access只影响属性在序列化和反序列化时的名称

springboot使用之请求参数与基本注解的更多相关文章

  1. SpringBoot获取http请求参数的方法

    SpringBoot获取http请求参数的方法 原文:https://www.cnblogs.com/zhanglijun/p/9403483.html 有七种Java后台获取前端传来参数的方法,稍微 ...

  2. springboot获取URL请求参数的多种方式

    1.直接把表单的参数写在Controller相应的方法的形参中,适用于get方式提交,不适用于post方式提交. /** * 1.直接把表单的参数写在Controller相应的方法的形参中 * @pa ...

  3. springboot获取URL请求参数的几种方法

    原文地址:http://www.cnblogs.com/xiaoxi/p/5695783.html 1.直接把表单的参数写在Controller相应的方法的形参中,适用于get方式提交,不适用于pos ...

  4. springmvc请求路径和请求参数的获取注解- @PathVariable和@RequestParam

    @PathVariable和@RequestParam @PathVariable是从路径里面去获取变量,也就是把路径当做变量. @RequestParam是从请求里面获取参数. 如:url:http ...

  5. SpringMVC之请求参数的获取方式

    转载出处:https://www.toutiao.com/i6510822190219264516/ SpringMVC之请求参数的获取方式 常见的一个web服务,如何获取请求参数? 一般最常见的请求 ...

  6. SpringMVC请求参数的获取方式

    一.GET请求参数获取 1. 通过HttpServletRequest获取参数 2. 直接方法参数获取 3. RequestParam注解方式获取请求参数 4. Bean方式获取参数 5. Model ...

  7. springboot(服务端接口)获取URL请求参数的几种方法

    原文地址:http://www.cnblogs.com/xiaoxi/p/5695783.html 一.下面为7种服务端获取前端传过来的参数的方法  常用的方法为:@RequestParam和@Req ...

  8. SpringBoot系列教程web篇之Post请求参数解析姿势汇总

    作为一个常年提供各种Http接口的后端而言,如何获取请求参数可以说是一项基本技能了,本篇为<190824-SpringBoot系列教程web篇之Get请求参数解析姿势汇总>之后的第二篇,对 ...

  9. SpringBoot系列教程web篇之Get请求参数解析姿势汇总

    一般在开发web应用的时候,如果提供http接口,最常见的http请求方式为GET/POST,我们知道这两种请求方式的一个显著区别是GET请求的参数在url中,而post请求可以不在url中:那么一个 ...

随机推荐

  1. Microfacet模型采样下的brdf

    本文前言 在学习图形学(games101 from bilibili)的时候,也遇到了像这样的问题,Cook-Torrance模型无法实现粗糙度为0时,物体微表面呈现绝对镜面的效果(呈现出一面镜子), ...

  2. P4780-Phi的反函数【dfs】

    正题 题目链接:https://www.luogu.com.cn/problem/P4780 题目大意 给出\(n\),求一个最小的\(x\)满足\(\varphi(x)=n\). 若不存在或者大于\ ...

  3. 基于python的pixiv爬虫

    基于python的pixiv爬虫 1.目标 在和朋友吹逼过程中,聊到qq群机器人,突发奇想动手做一个p站每日推荐色图的色图机,遂学习爬虫. 目标: 批量下载首页推荐色图. 由于对qq机器人不熟,先利用 ...

  4. equals之List

    School类 package com.collection.equals; /* * 定义一个学校类 相当于一个学校模板 * 状态: 1.学校id 2.学校名称 * */ public class ...

  5. java 从零开始手写 RPC (05) reflect 反射实现通用调用之服务端

    通用调用 java 从零开始手写 RPC (01) 基于 socket 实现 java 从零开始手写 RPC (02)-netty4 实现客户端和服务端 java 从零开始手写 RPC (03) 如何 ...

  6. Apache ShardingSphere 在京东白条场景的落地之旅

    京东白条使用 Apache ShardingSphere 解决了千亿数据存储和扩容的问题,为大促活动奠定了基础. 2014 年初,"京东白条"作为业内互联网信用支付产品,数据量爆发 ...

  7. CAD/DWG图Web网页可视化技术之栅格和矢量瓦片

    背景 在上一篇博文中CAD图DWG解析WebGIS可视化技术分析总结提到,实现CAD/DWG图形Web展示的思路一般为解析AutoCAD图形格式,然后转成html5所能绘制的格式如svg,geojso ...

  8. java设计模式_单例模式

    懒汉式 非线程安全 特点:Lazy 初始化.非多线程安全.易实现 描述:这种方式是最基本的实现方式,这种实现最大的问题就是不支持多线程.因为没有加锁 synchronized,所以严格意义上它并不算单 ...

  9. Java多线程编程实战指南 设计模式 读书笔记

    线程设计模式在按其有助于解决的多线程编程相关的问题可粗略分类如下. 不使用锁的情况下保证线程安全: Immutable Object(不可变对象)模式.Thread Specific Storage( ...

  10. Java(40)网络编程

    作者:季沐测试笔记 原文地址:https://www.cnblogs.com/testero/p/15201659.html 博客主页:https://www.cnblogs.com/testero ...