springboot2.x基础教程:springmvc参数绑定注解今天彻底搞清楚

在编写SpringBoot项目中我们通常在Controller层使用@RequestParam、@RequestBody等注解接收前端请求参数。
我们应该怎么使用各种注解,这片文章带大家把springmvc参数绑定使用彻底搞清楚。

Http请求报文

HTTP协议定义Web客户端如何从Web服务器请求Web页面,以及服务器如何把Web页面传送给客户端。
客户端向服务器发送一个请求报文,请求报文包含:

请求方法

  1. 在Springboot中请求方法最常用的是GET或者POST方法,其他的HEAD、PUT一般不会使用
  2. GET通常用于查询某个资源,POST通常用于新增、更新、删除资源操作。
  3. GET一般利用URL传递参数,POST利用请求体。
  4. URL的一般浏览器设定最大长度为1k,POST利用的请求体的无数据限制
  5. 在Http协议中没有规定GET不能利用请求体发送数据,实际上我们是可以这样做的。但是因为有些服务器实现可能直接把GET的请求体内容忽略掉,所以一般我们不会这样使用

请求URL

URL,全称是UniformResourceLocator, 中文叫统一资源定位符,是互联网上用来标识某一处资源的地址。

scheme:[//[user[:password]@]host[:port]][/path][?query][#fragment]
http://www.example.com:80/path/to/myfile.html?key1=value1&key2=value2#SomewhereInTheDocument

请求头部

请求头部由关键字/值对组成,每行一对,关键字和值用英文冒号“:”分隔。请求头部通知服务器有关于客户端请求的信息。

:authority: www.cnblogs.com
:method: GET
content-type: application/json; charset=utf-8
cookie: _ga=GA1.2.1704734765.1586779730; _gid=GA1.2.846324607.1598838524
pragma: no-cache
referer: https://www.cnblogs.com/
sec-fetch-dest: empty
sec-fetch-mode: cors
sec-fetch-site: same-origin
user-agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
x-requested-with: XMLHttpRequest

请求数据

协议规定post提交的数据,必须包含在消息主体中entity-body中,但是协议并没有规定数据使用什么编码方式。开发者可以自己决定消息主体的格式,服务端会根据content-type字段来获取参数是怎么编码的,然后对应去解码

常见的ContentType

1、application/x-www-form-urlencoded

浏览器的原生form表单提交的数据按照 key1=val1&key2=val2 的方式进行编码,key和val都进行了URL转码

2、multipart/form-data

常见的 POST 数据提交的方式。我们使用表单上传文件时,必须让 form 的 enctype 等于这个值。

3、application/json

消息主体是序列化后的 JSON 字符串

4、text/xml

使用 HTTP 作为传输协议,XML 作为编码方式的远程调用规范

SpringMVC参数绑定

@PathVariable注解详解

@PathVariable 是用来获得请求url中的动态参数的,可以将URL中的变量映射到功能处理方法的参数上,其中URL 中的 {xxx} 占位符可以通过@PathVariable(“xxx“) 绑定到操作方法的入参中。

@GetMapping("/user/{id}")
@ResponseBody
public R userInfo(@PathVariable("id")String id){
    return  R.ok(id);
}

@RequestHeader注解详解

@RequestHeader 注解,可以把Request请求header部分的值绑定到方法的参数上。

@GetMapping("/useragent")
@ResponseBody
public R getHeader(@RequestHeader("User-Agent")String userAgent){
   //...省略
}

@CookieValue注解详解

@CookieValue 可以把Request header中关于cookie的值绑定到方法的参数上。

@GetMapping("/cookie")
@ResponseBody
public R getCookie(@CookieValue("token")String token){
    //...省略
}

@RequestParam详解

@RequestParam注解用来处理Content-Type: 为 application/x-www-form-urlencoded编码的内容,提交方式为get或post。
@RequestParam注解实质是将Request.getParameter()中的Key-Value参数Map利用Spring的转化机制ConversionService配置,转化成参数接收对象或字段,RequestParam可以获取的到get方式中queryString的值,和post方式中body data的值

@RequestMapping("/reqparam")
@ResponseBody
public R requsetParam(@RequestParam Map<String,Object> params) {
    return R.ok(params);
}

get请求@RequestParam获取到了url上的参数:

post请求@RequestParam获取到了url上的参数和请求实体的参数:

@RequestParam同样可以用来处理Content-Type:为form/data的内容,通常用于文件上传

@RequestMapping("/upload")
@ResponseBody
public R requsetParam(@RequestParam("files") MultipartFile file,@RequestParam Map<String,Object> params) {
    params.put("files",file.getOriginalFilename());
    return R.ok(params);
}

@RequestBody详解

@RequestBody注解用来处理HttpEntity(请求体)传递过来的数据,一般用来处理非Content-Type: application/x-www-form-urlencoded编码格式的数据

@RequestBody获取Json数据

@RequestMapping("/json")
@ResponseBody
public R json(@RequestBody UserDO userDO){
    return R.ok(userDO);
}

@RequestBody获取xml数据

@RequestMapping(value = "/xml",consumes = "application/xml",produces ="application/xml",method = RequestMethod.POST)
@ResponseBody
public UserDO xml(@RequestBody UserDO userDO){
    return userDO;
}


千里之行,始于足下。这里是SpringBoot教程系列第十六篇,所有项目源码均可以在我的GitHub上面下载源码。

posted @ 2020-09-06 11:30  程序员众推  阅读(385)  评论(0编辑  收藏  举报