欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringMVC?@RequestMapping注解屬性詳細(xì)介紹

 更新時(shí)間:2023年02月10日 09:08:54   作者:楊宸楊  
通過@RequestMapping注解可以定義不同的處理器映射規(guī)則,下面這篇文章主要給大家介紹了關(guān)于SpringMVC中@RequestMapping注解用法的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

@RequestMapping注解的功能

從注解名稱上我們可以看到,@RequestMapping注解的作用是將請求和處理請求的方法關(guān)聯(lián)起來,建立映射關(guān)系

SpringMVC接收到指定的請求,就會(huì)來找到在映射關(guān)系中對應(yīng)的控制器方法來處理這個(gè)請求

@RequestMapping注解的位置

@RequestMapping標(biāo)識(shí)一個(gè)類:設(shè)置映射請求的請求路徑的初始信息

@RequestMapping標(biāo)識(shí)一個(gè)方法:設(shè)置映射請求請求路徑的具體信息

@RequestMapping注解的value屬性

1.@RequestMapping注解的value屬性通過請求的請求地址匹配映射

2.@RequestMapping注解的value屬性是一個(gè)字符串類型的數(shù)組,表示該請求映射能夠匹配多個(gè)請求地址所對應(yīng)的請求

3.@RequestMapping注解的value屬性必須設(shè)置,至少通過請求地址匹配請求映射

代碼展示

	@RequestMapping(value = "/target")
    public String toTarget(){
        return "target";
    }

或者value也可以是:

@RequestMapping(value = {"/testRequestMapping","test"})
    public String toTarget(){
        return "target";
    }

運(yùn)行結(jié)果:

@RequestMapping注解的method屬性

1.@RequestMapping注解的method屬性通過請求的請求方式(get或post)匹配請求映射

2.@RequestMapping注解的method屬性是一個(gè)RequestMethod類型的數(shù)組。表示該請求映射能夠匹配多種請求方式的請求

3.若當(dāng)前請求的請求地址滿足請求映射的value屬性,但是請求方式不滿足method屬性,則瀏覽器報(bào)錯(cuò)405:Request method "POST’ not supported 注:

1.對于處理指定請求方式的控制器方法,SpringMVC中提供了@RequestMapping的派生注解

處理get請求的映射–>GetMapping
處理post請求的映射–>PostMapping
處理put請求的映射–>PutMapping
處理delete請求的映射–>DeleteMapping

2.常用的請求方式有g(shù)et,post,put,delete

但是目前瀏覽器只支持get和post,若在form表單提交時(shí),為method設(shè)置了其他請求方式的字符串(put或delete),則按照默認(rèn)的請求方式get處理
若要發(fā)送put和delete請求,則需要通過spring提供的過濾器HiddenHttpMethodFilter,在restful部分會(huì)講到

默認(rèn)提交是get提交,假如我們發(fā)出一個(gè)post請求,會(huì)有什么反映

Controller:

 	@GetMapping("/testGetMapping")
    public String testGetMapping(){
        return "success";
    }

html:

<form th:action="@{/testGetMapping}" method="post">
    <input type="submit" value="測試RequestMapping注解的method屬性-->POST">
</form>

運(yùn)行結(jié)果

解決辦法:

將頁面的post請求變?yōu)間et請求

或者

給Controller程序里的的@RequestMapping中method屬性賦值

get和post的區(qū)別

get請求是將參數(shù)的值以這種

形式來請求指定的頁面信息,并返回實(shí)體主體,一般用于查詢操作

POST 向指定資源提交數(shù)據(jù)進(jìn)行處理請求(例如提交表單或者上傳文件)。 POST請求可能會(huì)導(dǎo)致新的資源的建立和/或已有資源的修改。

一般用于增刪改操作

@RequestMapping注解的params屬性

@RequestMapping注解的params屬性通過請求的請求參數(shù)匹配請求映射

@RequestMapping注解的params屬性通過請求的請求參數(shù)匹配請求映射
@RequestMapping注解的params屬性是一個(gè)字符串類型的數(shù)組,可以通過四種表達(dá)式設(shè)置請求參數(shù)和請求映射的匹配關(guān)系
“param”:要求請求映射所匹配的請求必須攜帶param請求參數(shù)"lparam":要求請求映射所匹配的請求必須不能攜帶param請求參數(shù)
“param=value”:要求請求映射所匹配的請求必須攜帶param請求參數(shù)且param=value
“param!=value”:要求請求映射所匹配的請求必須攜帶param請求參數(shù)但是param!=value

代碼樣例: 

html:

<a th:href="@{/testParamsAndHeaders(username='admin',password=123)}" rel="external nofollow"  rel="external nofollow" >測試RequestMapping注解的param屬性-->/testParamsAndHeaders</a>

Controller:

    @RequestMapping(
            value = "/testParamsAndHeaders",
            params = {"username","password!=123456"}
    )
    public String testParamsAndHeaders(){
        return "success";
    }

運(yùn)行結(jié)果:

若不滿足條件:

偏偏要將該密碼改為123456

@RequestMapping注解的headers屬性

什么是headers屬性

這些屬性全部可以當(dāng)作head屬性來使用

@RequestMapping注解的headers屬性通過請求的請求頭信息匹配請求映射
@RequestMapping注解的headers屬性是一個(gè)字符串類型的數(shù)組,可以通過四種表達(dá)式設(shè)置請求頭信息和請求映射的匹配關(guān)系
“header”:要求請求映射所匹配的請求必須攜帶header請求頭信息
“!header”:要求請求映射所匹配的請求必須不能攜帶header請求頭信息
“header=value”:要求請求映射所匹配的請求必須攜帶header請求頭信息且header=value
“header!=value”:要求請求映射所匹配的請求必須攜帶header請求頭信息且header!=value
若當(dāng)前請求滿足@RequestMapping注解的value和method屬性,但是不滿足headers屬性,此時(shí)頁面顯示404錯(cuò)誤,即資源未找到

代碼測試:

Controller:

    @RequestMapping(
            value = "/testParamsAndHeaders",
            params = {"username","password!=123456"},
            headers = {"Host=localhost:8084"}
    )
    public String testParamsAndHeaders(){
        return "success";
    }

Html:

<a th:href="@{/testParamsAndHeaders(username='admin',password=123)}" rel="external nofollow"  rel="external nofollow" >測試RequestMapping注解的head屬性-->/testParamsAndHeaders</a>

運(yùn)行結(jié)果:

404 --> value出錯(cuò)或者h(yuǎn)ead出錯(cuò)

400 --> param出錯(cuò)

405 --> method請求方式出錯(cuò)

到此這篇關(guān)于SpringMVC @RequestMapping注解屬性詳細(xì)介紹的文章就介紹到這了,更多相關(guān)SpringMVC @RequestMapping內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • springboot實(shí)現(xiàn)yml里的自定義配置方法

    springboot實(shí)現(xiàn)yml里的自定義配置方法

    這篇文章主要介紹了springboot實(shí)現(xiàn)yml里的自定義配置方法,主要介紹三種,字符串配置,數(shù)組配置和帶默認(rèn)值的配置,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • springboot實(shí)現(xiàn)文件上傳和下載功能

    springboot實(shí)現(xiàn)文件上傳和下載功能

    這篇文章主要為大家詳細(xì)介紹了springboot實(shí)現(xiàn)文件上傳和下載功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Java 回調(diào)函數(shù)詳解及使用

    Java 回調(diào)函數(shù)詳解及使用

    這篇文章主要介紹了Java 回調(diào)函數(shù)詳解及使用,附有簡單實(shí)例,需要的朋友可以參考下
    2017-03-03
  • Java驗(yàn)證日期時(shí)間字符串是否合法的三種方式

    Java驗(yàn)證日期時(shí)間字符串是否合法的三種方式

    判斷日期經(jīng)常合法出現(xiàn)在IO場景下,下面將盡量使用簡練的思路和代碼呈現(xiàn)給大伙,這篇文章主要給大家介紹了關(guān)于Java驗(yàn)證日期時(shí)間字符串是否合法的三種方式,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • SpringCloud實(shí)現(xiàn)基于RabbitMQ消息隊(duì)列的詳細(xì)步驟

    SpringCloud實(shí)現(xiàn)基于RabbitMQ消息隊(duì)列的詳細(xì)步驟

    在Spring Cloud框架中,我們可以利用RabbitMQ實(shí)現(xiàn)強(qiáng)大而可靠的消息隊(duì)列系統(tǒng),本篇將詳細(xì)介紹如何在Spring Cloud項(xiàng)目中集成RabbitMQ,并創(chuàng)建一個(gè)簡單的消息隊(duì)列,感興趣的朋友一起看看吧
    2024-03-03
  • Java消息隊(duì)列中的Kafka如何保證冪等性

    Java消息隊(duì)列中的Kafka如何保證冪等性

    這篇文章主要介紹了Java消息隊(duì)列中的Kafka如何保證冪等性,Kafka是一種消息隊(duì)列,主要用來處理大量數(shù)據(jù)狀態(tài)下的消息隊(duì)列,一般用來做日志的處理,既然是消息隊(duì)列,那么Kafka也就擁有消息隊(duì)列的相應(yīng)的特性了,需要的朋友可以參考下
    2023-07-07
  • java實(shí)現(xiàn)商品管理系統(tǒng)

    java實(shí)現(xiàn)商品管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)商品管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • Java 基礎(chǔ):string中的compareTo方法

    Java 基礎(chǔ):string中的compareTo方法

    這篇文章主要介紹了Java 基礎(chǔ):string中的compareTo方法,文章圍繞string中的compareTo方法的相關(guān)資料展開文章詳細(xì)內(nèi)容,希望對待大家有所幫助
    2021-12-12
  • 詳解SpringBoot同時(shí)可以處理多少請求

    詳解SpringBoot同時(shí)可以處理多少請求

    在日常操作中,相信很多人在SpringBoot能同時(shí)處理多少請求問題上存在疑惑,本文就來詳細(xì)的介紹一下,感興趣的可以了解一下
    2024-06-06
  • Java對象轉(zhuǎn)json JsonFormat注解

    Java對象轉(zhuǎn)json JsonFormat注解

    這篇文章主要介紹了Java對象轉(zhuǎn)json JsonFormat注解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05

最新評論