1. 程式人生 > 程式設計 >Spring mvc如何實現資料處理

Spring mvc如何實現資料處理

處理提交資料

1、提交的域名稱和處理方法的引數名一致

提交資料 : http://localhost:8080/hello?name=xiaohua

處理方法 :

@RequestMapping("/hello")
public String hello(String name){
  System.out.println(name);
  return "hello";
}

後臺輸出 : xiaohua

2、提交的域名稱和處理方法的引數名不一致

提交資料 : http://localhost:8080/hello?username=xiaohua

處理方法 :

//@RequestParam("username") : username提交的域的名稱 .
@RequestMapping("/hello")
public String hello(@RequestParam("username") String name){
  System.out.println(name);
  return "hello";
}

後臺輸出 : xiaohua

3、提交的是一個物件

要求提交的表單域和物件的屬性名一致,引數使用物件即可

實體類

public class User {
  private int id;
  private String name;
  private int age;
  //構造
  //get/set
  //tostring()
}

提交資料 : http://localhost:8080/mvc04/user?name=xiaohua&id=1&age=15

處理方法 :

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

後臺輸出 : User { id=1,name='xiaohua',age=15 }

說明:如果使用物件的話,前端傳遞的引數名和物件名必須一致,否則就是null。

資料顯示到前端

第一種 : 通過ModelAndView

我們前面一直都是如此 . 就不過多解釋

public class ControllerTest1 implements Controller {

  public ModelAndView handleRequest(HttpServletRequest httpServletRequest,HttpServletResponse httpServletResponse) throws Exception {
    //返回一個模型檢視物件
    ModelAndView mv = new ModelAndView();
    mv.addObject("msg","ControllerTest1");
    mv.setViewName("test");
    return mv;
  }
}

第二種 : 通過ModelMap

ModelMap

@RequestMapping("/hello")
public String hello(@RequestParam("username") String name,ModelMap model){
  //封裝要顯示到檢視中的資料
  //相當於req.setAttribute("name",name);
  model.addAttribute("name",name);
  System.out.println(name);
  return "hello";
}

第三種 : 通過Model

Model

@RequestMapping("/ct2/hello")
public String hello(@RequestParam("username") String name,Model model){
  //封裝要顯示到檢視中的資料
  //相當於req.setAttribute("name",name);
  model.addAttribute("msg",name);
  System.out.println(name);
  return "test";
}

對比

  • Model 只有寥寥幾個方法只適合用於儲存資料,簡化了對於Model物件的操作和理解;
  • ModelMap 繼承了 LinkedMap ,除了實現了自身的一些方法,同樣的繼承 LinkedMap 的方法和特性;
  • ModelAndView 可以在儲存資料的同時,可以進行設定返回的邏輯檢視,進行控制展示層的跳轉。

亂碼問題

SpringMVC給我們提供了一個過濾器,可以在web.xml中配置 .

修改了xml檔案需要重啟伺服器!

<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>

有些極端情況下.這個過濾器對get的支援不好 .

處理方法 :

修改tomcat配置檔案 : 設定編碼!

<Connector URIEncoding="utf-8" port="8080" protocol="HTTP/1.1"
      connectionTimeout="20000"
      redirectPort="8443" />

自定義過濾器

package com.xiaohua.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 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");

    // 轉型為與協議相關物件
    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中配置這個過濾器即可!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。