🏇 小 木 來 了 \textcolor{Orange}{小木來了} 小木來了
🍣 大 伙 們 有 沒 有 遇 到 亂 碼 的 問 題 , 真 的 是 讓 人 心 情 煩 躁 \textcolor{green}{大伙們有沒有遇到亂碼的問題,真的是讓人心情煩躁} 大伙們有沒有遇到亂碼的問題,真的是讓人心情煩躁🍣
🍣 今 天 就 來 看 下 數 據 怎 么 傳 輸 到 前 端 以 及 亂 碼 問 題 怎 么 解 決 \textcolor{green}{今天就來看下資料怎么傳輸到前端以及亂碼問題怎么解決} 今天就來看下數據怎么傳輸到前端以及亂碼問題怎么解決🍣
🙏 博 主 也 在 學 習 階 段 , 如 若 發 現 問 題 , 請 告 知 , 非 常 感 謝 \textcolor{Orange}{博主也在學習階段,如若發現問題,請告知,非常感謝} 博主也在學習階段,如若發現問題,請告知,非常感謝💗
所用到的代碼都可以在這里找到
資料處理和亂碼問題
- 八、資料處理
- 1. 處理提交資料
- 2. 資料顯示到前端
- 九、亂碼問題
八、資料處理
1. 處理提交資料
- 提交的名稱和方法的引數名一致
//localhost:8080/user/t1?name=xxx;
@GetMapping("/t1")
public String test1(String name, Model model){
//1.接收前端引數
System.out.println("接收到前端的引數為:" + name);
//2.將回傳的結果傳遞給前端
model.addAttribute("msg", name);
//3.跳轉視圖
return "test";
}
- 提交的名稱和方法的引數名不一致
//加上@RequestParam("username")就知道是從前端接收過來localhost:8080/user/t1?username=xxx;,此時必須要通過username識別
@GetMapping("/t1")
public String test1(@RequestParam("username") String name, Model model){
//1.接收前端引數
System.out.println("接收到前端的引數為:" + name);
//2.將回傳的結果傳遞給前端
model.addAttribute("msg", name);
//3.跳轉視圖
return "test";
}
- 提交一個物件
//前端接收的是一個物件:id, name, age
//localhost:8080/user/t1?id=1&name=xxx&age=2;
/*
* 1.接收前端用戶傳遞的引數,判斷引數的名字,假設名字直接在方法上可以直接使用
* 2.假設傳遞的是一個物件User,匹配User物件中的欄位名:如果名字一致則ok,否則匹配不到
*
* */
@GetMapping("/t2")
public String test2(User user){
System.out.println(user);
//3.跳轉視圖
return "test";
}
使用物件,前端傳遞的引數名和物件名必須一致,否則為空,
2. 資料顯示到前端
2.1 ModelAndView
public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
ModelAndView modelAndView = new ModelAndView();
modelAndView.addObject("msg","ControllerTest1");
modelAndView.setViewName("test");
return modelAndView;
}
2.2 Model
@RequestMapping("/t2")
public String test(Model model){
model.addAttribute("msg", "ControllerTest2");
return "test";
}
2.3 ModelMap
@GetMapping("/t3")
public String test3(@RequestParam("username") String name,Model map){
map.addAttribute("name",name);
return "test";
}
對比:
ModelAndView 可以在儲存資料的同時,可以進行設定回傳的邏輯視圖,進行控制展示層的跳轉,
ModelMap 繼承了 LinkedHashMap ,除了實作了自身的一些方法,同樣的繼承 LinkedHashMap 的方法和特性;
Model 少數方法適合用于儲存資料,簡化了新手對于Model物件的操作和理解;大部分情況下直接使用Model
九、亂碼問題
- form表單
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<form action="/encoding/t1" method="post">
<input type="text" name="name">
<input type="submit">
</form>
</body>
</html>
-
寫一個controller
@Controller public class EncodingController { @PostMapping("/encoding/t1") public String test(String name, Model model){ model.addAttribute("msg",name); return "test"; } } -
測驗結果

前 面 弄 得 好 好 的 , 結 果 出 了 個 這 \textcolor{red}{前面弄得好好的,結果出了個這} 前面弄得好好的,結果出了個這
解決辦法:
看一下自己Tomcat中的是不是設定的UTF-8,在自己下載路徑下-conf-server.xml
<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URLEncoding="UTF-8"/>
-
修改提交方式
把提交方式post方法改成get方法
-
Spring提供了過濾器,可以在web.xml中直接配置,(這個基本夠用)
<!--2.配置 SpringMVC的亂碼過濾--> <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> -
過濾器解決(這個不行,功能不全)
package com.hxl.filter; import javax.servlet.*; import java.io.IOException; public class EncodingFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { servletRequest.setCharacterEncoding("utf-8"); servletResponse.setCharacterEncoding("utf-8"); filterChain.doFilter(servletRequest,servletResponse); } @Override public void destroy() { } }寫完就要去注冊(web.xml)
<filter> <filter-name>encoding</filter-name> <filter-class>com.hxl.filter.EncodingFilter</filter-class> </filter> <filter-mapping> <filter-name>encoding</filter-name> <url-pattern>/</url-pattern> </filter-mapping> -
大神自定義過濾器
package com.hxl.filter; import javax.servlet.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequestWrapper; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.util.Map; /** * 解決get和post請求 全部亂碼的過濾器 */ public class EncodingFilter 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"); // 轉型為與協議相關物件 HttpServletRequest httpServletRequest = (HttpServletRequest) request; // 對request包裝增強 HttpServletRequest myrequest = new MyRequest(httpServletRequest); chain.doFilter(myrequest, response); } @Override public void init(FilterConfig filterConfig) throws ServletException { } } //自定義request物件,HttpServletRequest的包裝類 class MyRequest extends HttpServletRequestWrapper { private HttpServletRequest request; //是否編碼的標記 private boolean hasEncode; //定義一個可以傳入HttpServletRequest物件的建構式,以便對其進行裝飾 public MyRequest(HttpServletRequest request) { super(request);// super必須寫 this.request = request; } // 對需要增強方法 進行覆寫 @Override public Map getParameterMap() { // 先獲得請求方式 String method = request.getMethod(); if (method.equalsIgnoreCase("post")) { // post請求 try { // 處理post亂碼 request.setCharacterEncoding("utf-8"); return request.getParameterMap(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } } else if (method.equalsIgnoreCase("get")) { // get請求 Map<String, String[]> parameterMap = request.getParameterMap(); if (!hasEncode) { // 確保get手動編碼邏輯只運行一次 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(); } //取一個值 @Override public String getParameter(String name) { Map<String, String[]> parameterMap = getParameterMap(); String[] values = parameterMap.get(name); if (values == null) { return null; } return values[0]; // 取回引數的第一個值 } //取所有值 @Override public String[] getParameterValues(String name) { Map<String, String[]> parameterMap = getParameterMap(); String[] values = parameterMap.get(name); return values; } }同樣需要在web.xml中進行配置
看 看 這 個 , 膜 拜 \textcolor{Orange}{看看這個,膜拜} 看看這個,膜拜
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/374852.html
標籤:其他
下一篇:紅黑樹(C++實作)
