这篇文章主要介绍SpringBoot WebFlux中header参数的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
本项目借助SpringBoot 2.2.1.RELEASE
+ maven 3.5.3
+ IDEA
进行开发
使用 WebFlux,最主要的引入依赖如下(省略掉了 SpringBoot 的相关依赖,如对于如何创建 SpringBoot 项目不太清楚的小伙伴,可以关注一下我之前的博文)
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-webflux</artifactId> </dependency> </dependencies>
在实际的业务开发中,有几个请求头出现的频率特别高,如常用于反爬的User-Agent
,鉴定强求来源的referer
,跨域相关的Access-Control-Allow-
,cookie、session 自定义的请求头等
在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"}%
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%
利用 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%
以上是“SpringBoot WebFlux中header参数的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。