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)文章
一文搞懂JMeter engine中HashTree的配置問題
本文主要介紹了JMeter engine中HashTree的配置,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09Springboot登錄驗證的統(tǒng)一攔截處理的實現(xiàn)
如果不進行統(tǒng)一的攔截處理,每次用戶請求你都要去進行用戶的信息驗證,所以本文主要介紹了Springboot登錄驗證的統(tǒng)一攔截處理的實現(xiàn),感興趣的可以了解一下,感興趣的可以了解一下2023-09-09為什么程序中突然多了 200 個 Dubbo-thread 線程的說明
這篇文章主要介紹了為什么程序中突然多了 200 個 Dubbo-thread 線程的說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09