共计 2685 个字符,预计需要花费 7 分钟才能阅读完成。
【SpringBoot WebFlux 系列】WebFlux 之 header 参数解析
上一篇 weblfux 次要介绍了 path 参数的解析与映射关系,在咱们进入 url 参数 /post 表单之前,先看一下另外的一种参数 – 申请头中的参数如何解决
<!– more –>
I. 我的项目环境
本我的项目借助 SpringBoot 2.2.1.RELEASE
+ maven 3.5.3
+ IDEA
进行开发
1. 依赖
应用 WebFlux,最次要的引入依赖如下(省略掉了 SpringBoot 的相干依赖,如对于如何创立 SpringBoot 我的项目不太分明的小伙伴,能够关注一下我之前的博文)
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-webflux</artifactId>
</dependency>
</dependencies>
II. 申请头参数解析
在理论的业务开发中,有几个申请头呈现的频率特地高,如常用于反爬的User-Agent
,鉴定强求起源的referer
,跨域相干的Access-Control-Allow-
,cookie、session 自定义的申请头等
1. 申请头限度
在 RequestMapping
或GetMapping
中指定申请头参数时,示意只有申请中蕴含这个申请头才会匹配过来
/**
* 只有申请头蕴含 myheader 且值为 myvalue 的才能够拜访到
*
* - 失常拜访: curl 'http://127.0.0.1:8080/header/filter/yihhui' -H 'myheader: myvalue'
* - 异样拜访: curl 'http://127.0.0.1:8080/header/filter/yihhui' -H 'myheader: myvalue2' 因为申请头不匹配,404
*
* @param name
* @return
*/
@GetMapping(path = "/filter/{name}", headers = "myheader=myvalue")
public Mono<String> headerFilter(@PathVariable(name = "name") String name) {return Mono.just("request filter:" + name);
}
实例如下:
➜ ~ curl 'http://127.0.0.1:8080/header/filter/yihhui' -H 'myheader: myvalue'
request filter: yihhui%
➜ ~ curl 'http://127.0.0.1:8080/header/filter/yihhui' -H 'myheader: myvalue2'
{"timestamp":"2020-09-07T00:40:34.493+0000","path":"/header/filter/yihhui","status":404,"error":"Not Found","message":null,"requestId":"aa47f5a5"}%
2. 申请头参数解析
WebFlux 仍然是能够通过注解 @RequestHeader
来获取对应的申请头
从应用姿态上来看,webflux 与 webmvc 并没有什么区别
/**
* 获取申请头
*
* curl 'http://127.0.0.1:8080/header/get' -H 'myheader: myvalue' -H 'user-agent: xxxxxxx'
*
* @param header 留神,这个是自定义的申请头
* @param userAgent
* @return
*/
@GetMapping(path = "get")
public Mono<String> getHeader(@RequestHeader("myheader") String header,
@RequestHeader("user-agent") String userAgent) {return Mono.just("request headers: myheader=" + header + "userAgent=" + userAgent);
}
测试 case 如下
➜ ~ curl 'http://127.0.0.1:8080/header/get' -H 'myheader: myvalue' -H 'user-agent: xxxxxxx'
request headers: myheader=myvalue userAgent=xxxxxxx%
3. cookie 获取
利用 cookie 来标识用户身份能够说是十分广泛的场景了,咱们通过专用的 CookieValue
来获取指定的 cookies 值
/**
* 获取 cookie
*
* curl 'http://127.0.0.1:8080/header/cookie' --cookie 'tid=12343123;tt=abc123def'
*
* @param tid
* @return
*/
@GetMapping(path = "cookie")
public Mono<String> getCookie(@CookieValue("tid") String tid) {return Mono.just("request cookies tid=" + tid);
}
下面的 case 中,标识只须要获取 tid 这个 cookies 值,其余的不 care
➜ ~ curl 'http://127.0.0.1:8080/header/cookie' --cookie 'tid=12343123;tt=abc123def'
request cookies tid=12343123%
II. 其余
0. 我的项目
- 工程:https://github.com/liuyueyi/spring-boot-demo
- 源码: https://github.com/liuyueyi/spring-boot-demo/tree/master/spring-boot/223-webflux-params
系列博文
- 【WBE 系列】WebFlux 之 Path 参数解析与 url 映射
1. 一灰灰 Blog
尽信书则不如,以上内容,纯属一家之言,因集体能力无限,不免有疏漏和谬误之处,如发现 bug 或者有更好的倡议,欢送批评指正,不吝感谢
上面一灰灰的集体博客,记录所有学习和工作中的博文,欢送大家前去逛逛
- 一灰灰 Blog 集体博客 https://blog.hhui.top
- 一灰灰 Blog-Spring 专题博客 http://spring.hhui.top