Spring MVC數(shù)據(jù)處理和亂碼問(wèn)題詳解
一、數(shù)據(jù)處理
1.1 處理提交數(shù)據(jù)
1.1.1 提交的域名稱和處理方法的參數(shù)名一致
提交數(shù)據(jù):http://localhost:8080/hello?name=test
處理方法:
@RequestMapping("/hello")
public String hello(String name){
System.out.println(name);
return "hello";
}
后臺(tái)輸出test

1.1.2 提交的域名稱和處理方法的參數(shù)名不一致
提交數(shù)據(jù):http://localhost:8080/hello?username=test
處理方法:
//@RequestParam("username") : username提交的域的名稱 .
@RequestMapping("/hello")
public String hello(@RequestParam("username") String name){
System.out.println(name);
return "hello";
}

1.1.3 提交的是一個(gè)對(duì)象
要求提交的表單域和對(duì)象的屬性名一致,參數(shù)使用對(duì)象即可
1. 實(shí)體類(lèi)
@Getter
@Setter
@AllArgsConstructor
@NoArgsConstructor
public class User {
private int id;
private String name;
private int age;
}
2. 提交數(shù)據(jù):
http://localhost:8080/mvc04/user?name=test&id=1&age=15
3. 處理方法
@RequestMapping("/user")
public String user(User user){
System.out.println(user);
return "hello";
}
后臺(tái)輸出 : User { id=1, name='test', age=15 }
說(shuō)明:如果使用對(duì)象的話,前端傳遞的參數(shù)名和對(duì)象名必須一致,否則就是null。
1.2 數(shù)據(jù)顯示到前端
1.2.1 通過(guò)ModelAndView
public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
//返回一個(gè)模型視圖對(duì)象
ModelAndView mv = new ModelAndView();
mv.addObject("msg","ControllerTest1");
mv.setViewName("test");
return mv;
}
}
1.2.2 通過(guò)ModelMap
@RequestMapping("/hello")
public String hello(@RequestParam("username") String name, ModelMap model){
//封裝要顯示到視圖中的數(shù)據(jù)
//相當(dāng)于req.setAttribute("name",name);
model.addAttribute("name",name);
System.out.println(name);
return "hello";
}
1.2.3 通過(guò)Model
@RequestMapping("/ct2/hello")
public String hello(@RequestParam("username") String name, Model model){
//封裝要顯示到視圖中的數(shù)據(jù)
//相當(dāng)于req.setAttribute("name",name);
model.addAttribute("msg",name);
System.out.println(name);
return "test";
}
1.2.4 對(duì)比
就對(duì)于新手而言簡(jiǎn)單來(lái)說(shuō)使用區(qū)別就是:
Model 只有寥寥幾個(gè)方法只適合用于儲(chǔ)存數(shù)據(jù),簡(jiǎn)化了新手對(duì)于Model對(duì)象的操作和理解;
ModelMap 繼承了 LinkedMap ,除了實(shí)現(xiàn)了自身的一些方法,同樣的繼承 LinkedMap 的方法和特性;
ModelAndView 可以在儲(chǔ)存數(shù)據(jù)的同時(shí),可以進(jìn)行設(shè)置返回的邏輯視圖,進(jìn)行控制展示層的跳轉(zhuǎn)。
二、亂碼問(wèn)題
2.1 新建form表單
在web目錄下編寫(xiě)一個(gè)提交表單,注意開(kāi)啟視圖解析器
<form action="/e/t" method="post"> <input type="text" name="name"> <input type="submit"> </form>
2.2 后臺(tái)編寫(xiě)對(duì)應(yīng)的處理類(lèi)
@Controller
public class EncodingController {
@RequestMapping("/e/t")
public String test1(String name, Model model) {
System.out.println(name);
//獲取表達(dá)提交的值
model.addAttribute("msg", name);
//跳轉(zhuǎn)到test頁(yè)面顯示輸入的值
return "test";
}
}
2.3 測(cè)試


三、亂碼問(wèn)題解決
3.1 web.xml文件配置編碼過(guò)濾器
不得不說(shuō),亂碼問(wèn)題是在我們開(kāi)發(fā)中十分常見(jiàn)的問(wèn)題,也是讓我們程序猿比較頭大的問(wèn)題!
以前亂碼問(wèn)題通過(guò)過(guò)濾器解決 , 而SpringMVC給我們提供了一個(gè)過(guò)濾器 , 可以在web.xml中配置
修改了xml文件需要重啟服務(wù)器!
<filter> <filter-name>encoding</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> </filter> <filter-mapping> <filter-name>encoding</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
但是我們發(fā)現(xiàn) , 有些極端情況下.這個(gè)過(guò)濾器對(duì)get的支持不好 .
處理方法 :
3.1.1 修改tomcat配置文件:
<Connector URIEncoding="utf-8" port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />


<!--配置SpringMVC的亂碼過(guò)濾,注意/*--> <filter> <filter-name>encoding</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> </filter> <filter-mapping> <filter-name>encoding</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
3.1.2 自定義過(guò)濾器
/**
* 解決get和post請(qǐng)求 全部亂碼的過(guò)濾器
*/
public class GenericEncodingFilter implements Filter {
@Override
public void destroy() {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
//處理response的字符編碼
HttpServletResponse myResponse=(HttpServletResponse) response;
myResponse.setContentType("text/html;charset=UTF-8");
// 轉(zhuǎn)型為與協(xié)議相關(guān)對(duì)象
HttpServletRequest httpServletRequest = (HttpServletRequest) request;
// 對(duì)request包裝增強(qiáng)
HttpServletRequest myrequest = new MyRequest(httpServletRequest);
chain.doFilter(myrequest, response);
}
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
}
//自定義request對(duì)象,HttpServletRequest的包裝類(lèi)
class MyRequest extends HttpServletRequestWrapper {
private HttpServletRequest request;
//是否編碼的標(biāo)記
private boolean hasEncode;
//定義一個(gè)可以傳入HttpServletRequest對(duì)象的構(gòu)造函數(shù),以便對(duì)其進(jìn)行裝飾
public MyRequest(HttpServletRequest request) {
super(request);// super必須寫(xiě)
this.request = request;
}
// 對(duì)需要增強(qiáng)方法 進(jìn)行覆蓋
@Override
public Map getParameterMap() {
// 先獲得請(qǐng)求方式
String method = request.getMethod();
if (method.equalsIgnoreCase("post")) {
// post請(qǐng)求
try {
// 處理post亂碼
request.setCharacterEncoding("utf-8");
return request.getParameterMap();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
} else if (method.equalsIgnoreCase("get")) {
// get請(qǐng)求
Map<String, String[]> parameterMap = request.getParameterMap();
if (!hasEncode) { // 確保get手動(dòng)編碼邏輯只運(yùn)行一次
for (String parameterName : parameterMap.keySet()) {
String[] values = parameterMap.get(parameterName);
if (values != null) {
for (int i = 0; i < values.length; i++) {
try {
// 處理get亂碼
values[i] = new String(values[i]
.getBytes("ISO-8859-1"), "utf-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
}
}
hasEncode = true;
}
return parameterMap;
}
return super.getParameterMap();
}
//取一個(gè)值
@Override
public String getParameter(String name) {
Map<String, String[]> parameterMap = getParameterMap();
String[] values = parameterMap.get(name);
if (values == null) {
return null;
}
return values[0]; // 取回參數(shù)的第一個(gè)值
}
//取所有值
@Override
public String[] getParameterValues(String name) {
Map<String, String[]> parameterMap = getParameterMap();
String[] values = parameterMap.get(name);
return values;
}
}
然后在web.xml中配置這個(gè)過(guò)濾器即可!

到此這篇關(guān)于Spring MVC數(shù)據(jù)處理和亂碼問(wèn)題詳解的文章就介紹到這了,更多相關(guān)Spring MVC數(shù)據(jù)處理和亂碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringMVC集成redis配置的多種實(shí)現(xiàn)方法
- 淺談springMVC中controller的幾種返回類(lèi)型
- Spring MVC獲取HTTP請(qǐng)求頭的兩種方式小結(jié)
- 解決SpringMVC項(xiàng)目連接RabbitMQ出錯(cuò)的問(wèn)題
- SpringMVC和rabbitmq集成的使用案例
- SpringMVC異步處理操作(Callable和DeferredResult)
- springmvc 結(jié)合ajax批量新增的實(shí)現(xiàn)方法
- 基于IDEA創(chuàng)建SpringMVC項(xiàng)目流程圖解
- SpringMVC使用@PathVariable接收參數(shù)過(guò)程解析
- 如何理解SpringMVC
相關(guān)文章
SpringBoot使用Redis對(duì)用戶IP進(jìn)行接口限流的示例詳解
使用接口限流的主要目的在于提高系統(tǒng)的穩(wěn)定性,防止接口被惡意打擊,這篇文章主要介紹了SpringBoot使用Redis對(duì)用戶IP進(jìn)行接口限流的示例代碼,需要的朋友可以參考下2023-07-07
SpringBoot使用@Validated處理校驗(yàn)的方法步驟
@Validated?注解的主要目的是啟用和利用?Spring?的驗(yàn)證框架,它可以用于類(lèi)上也可以用于方法參數(shù)上,本文給大家介紹了SpringBoot使用@Validated優(yōu)雅的處理校驗(yàn)的方法步驟,通過(guò)代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2024-08-08
Java并發(fā)線程之線程池的知識(shí)總結(jié)
這篇文章主要介紹了Java并發(fā)線程之線程池的知識(shí)總結(jié),幫助大家更好的理解和學(xué)習(xí)Java并發(fā)線程的相關(guān)內(nèi)容,感興趣的朋友可以了解下2021-01-01
談?wù)凧ava利用原始HttpURLConnection發(fā)送POST數(shù)據(jù)
這篇文章主要給大家介紹java利用原始httpUrlConnection發(fā)送post數(shù)據(jù),設(shè)計(jì)到httpUrlConnection類(lèi)的相關(guān)知識(shí),感興趣的朋友跟著小編一起學(xué)習(xí)吧2015-10-10
一文搞懂Java?ScheduledExecutorService的使用
JUC包(java.util.concurrent)中提供了對(duì)定時(shí)任務(wù)的支持,即ScheduledExecutorService接口。本文主要對(duì)ScheduledExecutorService的使用進(jìn)行簡(jiǎn)單的介紹,需要的可以參考一下2022-11-11
SpringBoot前端傳遞數(shù)組后端接收兩種常用的方法
這篇文章主要給大家介紹了關(guān)于SpringBoot前端傳遞數(shù)組后端接收兩種常用的方法,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-04-04
springboot+spring?data?jpa實(shí)現(xiàn)新增及批量新增方式
這篇文章主要介紹了springboot+spring?data?jpa實(shí)現(xiàn)新增及批量新增方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11

