Spring mvc如何实现数据处理

网友投稿 446 2023-06-18

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文件需要重启服务器!

encoding

org.springframework.web.filter.CharacterEncodingFilter

encoding

utf-8

encoding

/

有些极端情况下.这个过滤器对get的支持不好 .

处理方法 :

修改tomcat配置文件 : 设置编码!

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 MyRequeDCRnCHBiVOst(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 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 parameterMap = getParameterMap();

String[] values = parameterMap.get(name);

if (values == null) {

return null;

}

return values[0]; // 取回参数的第一个值

}

//取所有值

@Override

public String[] getParameterValues(String name) {

Map parameterMap = getParameterMap();

String[] values = parameterMap.get(name);

return values;

}

}

然后在web.xml中配置这个过滤器即可!

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 MyRequeDCRnCHBiVOst(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 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 parameterMap = getParameterMap();

String[] values = parameterMap.get(name);

if (values == null) {

return null;

}

return values[0]; // 取回参数的第一个值

}

//取所有值

@Override

public String[] getParameterValues(String name) {

Map parameterMap = getParameterMap();

String[] values = parameterMap.get(name);

return values;

}

}

然后在web.xml中配置这个过滤器即可!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:MyBatis缓存功能原理及实例解析
下一篇:Spring mvc结果跳转方法详解
相关文章

 发表评论

暂时没有评论,来抢沙发吧~