91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot WebFlux中header參數的示例分析

發布時間:2021-12-16 17:22:15 來源:億速云 閱讀:421 作者:小新 欄目:大數據

這篇文章主要介紹SpringBoot WebFlux中header參數的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

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. 請求頭限制

RequestMappingGetMapping中指定請求頭參數時,表示只有請求中包含這個請求頭才會匹配過去

/**
 * 只有請求頭包含 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%

以上是“SpringBoot WebFlux中header參數的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

连城县| 镶黄旗| 丹江口市| 新疆| 福安市| 定兴县| 青铜峡市| 潢川县| 高邑县| 靖远县| 乌苏市| 合肥市| 隆昌县| 阜阳市| 全州县| 仪陇县| 库尔勒市| 吉木萨尔县| 贡嘎县| 襄垣县| 蒙城县| 赤壁市| 清流县| 滦平县| 兰州市| 博客| 长子县| 丘北县| 古丈县| 象山县| 含山县| 太保市| 荥阳市| 海宁市| 大关县| 铜梁县| 牡丹江市| 滦平县| 邹平县| 彰化市| 池州市|