亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringMVC中請求參數(shù)的獲取方式

 更新時間:2022年05月30日 08:42:05   作者:把蘋果咬哭的測試筆記  
這篇文章主要為大家介紹了SpringMVC中請求參數(shù)的獲取方式,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

SpringMVC請求參數(shù)獲取方式

一、通過 ServletAPI 獲取

可以使用原生 Servlet 獲取請求參數(shù),將 HttpServletRequest 作為控制器方法的形參,此時 HttpServletRequest 類型的參數(shù)表示封裝了當(dāng)前請求的請求報文的對象。

有兩種常用的方法。

使用 getParameter()方法獲取指定字段的值,如果有重名的字段,只獲取第一個。

@RequestMapping("/testParam")
public String testParam(HttpServletRequest request){
    String username = request.getParameter("username");
    String password = request.getParameter("password");
    System.out.println("username:"+username+",password:"+password);
    return "success";
}

如果要獲取同字段的多個值,使用request.getParameterValues()方法,比如:

<form name="checkform" method="post" action="getvalue.jsp">    
    你希望學(xué)習(xí)哪些程式語言:<br>    
    <input type="checkbox" name="langtype" value="JSP">JSP     
    <input type="checkbox" name="langtype" value="PHP">PHP     
    <input type="checkbox" name="langtype" value="PERL">PERL    
    <input type="submit" name="b1" value="送出">    
    </form>

這個 form 表單中,幾個 input type 的 name 都叫做 langtype,用getParameterValues("langtype"),得到字符串類型的數(shù)組。

二、通過控制器方法的形參獲取

在控制器方法的形參位置,設(shè)置和請求參數(shù)同名的形參。

當(dāng)瀏覽器發(fā)送請求,匹配到請求映射時,在 DispatcherServlet 中就會將請求參數(shù)賦值給相應(yīng)的形參。

@RequestMapping("/testParam")
    public String testParam(String username, String password){
        System.out.println("username:" + username + ",password:" + password);
        return "success";
    }

在頁面中發(fā)起請求:

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>測試請求參數(shù)</title>
</head>
<body>
    <h1>測試請求參數(shù)</h1>
    <a th:href="@{/testParam(username='admin',password=123456)}">測試獲取請求參數(shù)-->/testParam</a><br>
</body>
</html>

查看 idea 的控制器輸出日志,可以看到成功獲取到了形參對應(yīng)位置的請參數(shù)。

處理多個同名的請求參數(shù)

使用 springmvc 也會遇到多個參數(shù)同名的請求,還是用一個表單來說明,里面有一個復(fù)選框:

<form th:action="@{/testParam}" method="post">
        用戶名:<input type="text" name="username"><br>
        密碼:<input type="password" name="password"><br>
        愛好:<input type="checkbox" name="hobby" value="a">a
        <input type="checkbox" name="hobby" value="b">b
        <input type="checkbox" name="hobby" value="c">c<br>
        <input type="submit" value="提交">
    </form>

對應(yīng)的在后端代碼里,增加這個新參數(shù) hobby :

@RequestMapping("/testParam")
    public String testParam(String username, String password, String hobby){
        System.out.println("username:" + username + ",password:" + password + "hobby:" + hobby);
        return "success";
    }

現(xiàn)在勾選上3個復(fù)選框,提交請求,看下 hobby的值是什么。

可以看到,a,b,c是用逗號拼接在一起的。其實這種也可以用,只不過不太方便。

這里還可以使用另一種方法,在控制器方法的形參中設(shè)置字符串?dāng)?shù)組,這里就是String[] hobby:

@RequestMapping("/testParam")
    public String testParam(String username, String password, String[] hobby){
        System.out.println("username:" + username + ",password:" + password + ",hobby:" + Arrays.toString(hobby));
        return "success";
    }

重新提交下請求,取到的參數(shù)就是數(shù)組了,這樣取里面的單個值就方便了。

三、通過 @RequestParam 注解

在上面的控制器方法的形參獲取中,形參和請求的參數(shù)名需要一致才行,那如果不一致的情況怎么處理,那就是使用 @RequestParam 注解。

@RequestParam 是將請求參數(shù)和控制器方法的形參創(chuàng)建映射關(guān)系。

修改下上面的 form 表單,把參數(shù)名從 username 改成 username:

<form th:action="@{/testParam}" method="post">
        用戶名:<input type="text" name="user_name"><br>
        密碼:<input type="password" name="password"><br>
        愛好:<input type="checkbox" name="hobby" value="a">a
        <input type="checkbox" name="hobby" value="b">b
        <input type="checkbox" name="hobby" value="c">c<br>
        <input type="submit" value="提交">
    </form>

這時候發(fā)送請求,控制器是中的形參 username 就拿不到值了。

修改后端代碼,加上 @RequestParam注解:

@RequestMapping("/testParam")
    public String testParam(@RequestParam("user_name") String username, String password, String[] hobby){
        System.out.println("username:" + username + ",password:" + password + ",hobby:" + Arrays.toString(hobby));
        return "success";
    }

重新部署執(zhí)行請求,username 可以拿到值。

在 @RequestParam 注解中有三個屬性:

value:指定為形參賦值的請求參數(shù)的參數(shù)名

required:設(shè)置是否必須傳輸此請求參數(shù),默認值為true。

若沒有傳輸該請求參數(shù),且沒有設(shè)置 defaultValue 屬性,則頁面報錯400:Required String parameter 'xxx' is not present;

若設(shè)置為 false,則當(dāng)前請求不是必須傳輸 value 所指定的請求參數(shù),若沒有傳輸,則注解所標(biāo)識的形參的值為 null。

defaultValue:不管 required 屬性值為 true 還是 false,當(dāng) value 所指定的請求參數(shù)沒有傳輸或傳輸?shù)闹禐?quot;"時,則使用默認值為形參賦值。

四、@RequestHeader 注解

@RequestHeader是將請求頭信息和控制器方法的形參創(chuàng)建映射關(guān)系。

有著與@RequestParam一樣的三個屬性:value、required、defaultValue,用法也一樣。

比如,現(xiàn)在要接受 Header 里的 Host 值,修改控制器代碼:

@RequestMapping("/testParam")
    public String testParam(@RequestParam("user_name") String username,
                                String password,
                                String[] hobby,
                            @RequestHeader("Host") String host){
        System.out.println("username:" + username +
                        ",password:" + password +
                        ",hobby:" + Arrays.toString(hobby) +
                        "host: " + host);
        return "success";

這里使用@RequestHeader("Host") String host,將 Host 與 形參 host 綁定,成功獲取 Header 里 Host 的值。

五、@CookieValue 注解

@CookieValue是將 cookie 數(shù)據(jù)和控制器方法的形參創(chuàng)建映射關(guān)系。

有著與@RequestParam一樣的三個屬性:value、required、defaultValue,用法也一樣。

我在另一個請求控制器里使用 HttpSession,設(shè)置 session:

@GetMapping("/test3")
    public String testGetMapping(HttpServletRequest request) {
        HttpSession session =  request.getSession();
        return "success";
    }

當(dāng)?shù)谝淮卧L問/test3的時候,響應(yīng)報文里就會返回 JSESSIONID,key 就是 JSESSIONID,value 就是后面的隨機序列。

當(dāng)不關(guān)閉瀏覽器,繼續(xù)訪問這個頁面或者其他頁面時,JSESSIONID 就會出現(xiàn)在請求頭信息里了,比如現(xiàn)在訪問/param:

ok,繼續(xù)修改后端控制器的代碼,使用@CookieValue來獲取 cookie:

@RequestMapping("/testParam")
    public String testParam(@RequestParam("user_name") String username,
                                String password,
                                String[] hobby,
                            @RequestHeader("Host") String host,
                            @CookieValue("JSESSIONID") String jsessionid){
        System.out.println("username:" + username +
                        ",password:" + password +
                        ",hobby:" + Arrays.toString(hobby) +
                        ",host: " + host +
                        ",JSESSIONID: " + jsessionid);
        return "success";
    }

重新部署,發(fā)送請求。

查看控制臺獲取成功。

六、通過 POJO 獲取請求參數(shù)

在具體開發(fā)的時候,可能需要實現(xiàn)某些功能,比如添加,涉及到的字段就非常的多,再像上面那樣添加就不現(xiàn)實了。

那么,我們可以在控制器方法的形參位置設(shè)置一個實體類類型的形參,此時若瀏覽器傳輸?shù)恼埱髤?shù)的參數(shù)名和實體類中的屬性名一致,那么請求參數(shù)就會為此屬性賦值。

現(xiàn)在有個新的 form 表單:

<form th:action="@{/testpojo}" method="post">
    用戶名:<input type="text" name="username"><br>
    密碼:<input type="password" name="password"><br>
    性別:<input type="radio" name="sex" value="男">男<input type="radio" name="sex" value="女">女<br>
    年齡:<input type="text" name="age"><br>
    郵箱:<input type="text" name="email"><br>
    <input type="submit">
</form>

接著新建個實體類 User:

public class User {
    private Integer id;
    private String username;
    private String password;
    private Integer age;
    private String sex;
    private String email;
... ...

后面 加上構(gòu)造方法、get和set方法、toString方法。

不需要手寫,idea中右擊,再點擊 Generate,然后就可以選擇你要統(tǒng)一生成的代碼了。

繼續(xù),再寫一個接收/testpojo請求的控制器:

@RequestMapping("/testpojo")
    public String testPOJO(User user){
        System.out.println(user);
        return "success";
    }

注意,這里就直接使用了實體類對象 user 作為形參。

部署提交表單請求。

查看結(jié)果。

七、解決獲取請求參數(shù)的亂碼問題

在上面獲取 sex 值的時候出現(xiàn)了亂碼,因為字符編碼不一致。

可以使用 SpringMVC 提供的編碼過濾器CharacterEncodingFilter,但是必須在 web.xml中進行注冊才可以使用。

<!--配置 springMVC 的編碼過濾器-->
<filter>
    <filter-name>CharacterEncodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF-8</param-value>
    </init-param>
    <init-param>
        <param-name>forceResponseEncoding</param-name>
        <param-value>true</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>CharacterEncodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

重試看下效果。

不再亂碼了。

感謝《尚硅谷》的學(xué)習(xí)資源。

以上就是SpringMVC中請求參數(shù)的獲取方式的詳細內(nèi)容,更多關(guān)于SpringMVC請求參數(shù)獲取的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 網(wǎng)關(guān)Gateway過濾器的使用詳解

    網(wǎng)關(guān)Gateway過濾器的使用詳解

    Gateway網(wǎng)關(guān)的過濾器分為兩種,一種是局部過濾器,一種是全局過濾器,過濾器就是過濾一些請求,在這里,全局過濾器的作用是處理一切進入網(wǎng)關(guān)的請求和微服務(wù)響應(yīng),與GatewayFilter的作用一樣,本文給大家介紹網(wǎng)關(guān)Gateway過濾器的使用,感興趣的朋友一起看看吧
    2022-07-07
  • apache commons工具集代碼詳解

    apache commons工具集代碼詳解

    這篇文章主要介紹了apache commons工具集代碼詳解,具有一定借鑒價值,需要的朋友可以參考下
    2017-12-12
  • 一文搞懂JMeter engine中HashTree的配置問題

    一文搞懂JMeter engine中HashTree的配置問題

    本文主要介紹了JMeter engine中HashTree的配置,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Java8新特性之接口中的默認方法和靜態(tài)方法

    Java8新特性之接口中的默認方法和靜態(tài)方法

    這篇文章主要介紹了Java8新特性之接口中的默認方法和靜態(tài)方法的相關(guān)資料,文中講解非常細致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • idea 自動生成類注釋和方法注釋的實現(xiàn)步驟

    idea 自動生成類注釋和方法注釋的實現(xiàn)步驟

    這篇文章主要介紹了idea 自動生成類注釋和方法注釋的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • linux配置jdk環(huán)境變量簡單教程

    linux配置jdk環(huán)境變量簡單教程

    這篇文章主要為大家詳細介紹了linux配置jdk環(huán)境變量簡單教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • Springboot登錄驗證的統(tǒng)一攔截處理的實現(xiàn)

    Springboot登錄驗證的統(tǒng)一攔截處理的實現(xiàn)

    如果不進行統(tǒng)一的攔截處理,每次用戶請求你都要去進行用戶的信息驗證,所以本文主要介紹了Springboot登錄驗證的統(tǒng)一攔截處理的實現(xiàn),感興趣的可以了解一下,感興趣的可以了解一下
    2023-09-09
  • 為什么程序中突然多了 200 個 Dubbo-thread 線程的說明

    為什么程序中突然多了 200 個 Dubbo-thread 線程的說明

    這篇文章主要介紹了為什么程序中突然多了 200 個 Dubbo-thread 線程的說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • 簡單易懂講解happens-before原則

    簡單易懂講解happens-before原則

    Java內(nèi)存模型中的happens-before是什么?為什么會有這東西的存在?一個新東西肯定是上手先,但是等我們空下來回過頭來,我們還是需要去理解這些知識,只有這樣我才能深刻的記住,并且運用熟練。下來和小編來一起學(xué)習(xí)下
    2019-05-05
  • java實現(xiàn)簡單掃雷游戲

    java實現(xiàn)簡單掃雷游戲

    這篇文章主要為大家詳細介紹了java實現(xiàn)簡單掃雷游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04

最新評論