【SpringMVC】四、数据接收、发送及乱码问题【狂神篇】

public String test7(@PathVariable(“username”) String name, ModelMap map) {

System.out.println(“接收到的数据:” + name);

//ModelMap map = new ModelMap(); 不能自已定义

map.addAttribute(“msg”, name);

map.put(“info”, “Hello”);

return “hello”;

}

3)Model (建议使用)

与ModelMap类似;更简洁,没有put方法

@RequestMapping(“/t8/{username}”)

public String test8(@PathVariable(“username”) String name, Model model) {

System.out.println(“接收到的数据:” + name);

model.addAttribute(“msg”, name);

model.addAttribute(“info”, “Hello”);

return “hello”;

}

5.3、乱码问题


1)产生原因

数据的发送端与接收端对数据的编码格式不一致

  • form表单
  • 接收方法

@PostMapping(“/e/t1”)

public String test1(String name, Model model){

System.out.println(name);

model.addAttribute(“msg”,name);

return “hello”;

}

在这里插入图片描述

2)解决方案

使用过滤器

配置过滤器时,使用/*,可以过滤所有路径,包括.jsp等;不要用/,不能过滤.jsp等静态资源

(1)自定义过滤器
  • EncodingFileter.java

public class EncodingFileter implements Filter {

@Override

public void init(FilterConfig filterConfig) throws ServletException {

}

@Override

public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) throws IOException, ServletException {

request.setCharacterEncoding(“utf-8”);

response.setCharacterEncoding(“utf-8”);

filterChain.doFilter(request, response);

}

@Override

public void destroy() {

}

}

  • web.xml中配置过滤器

encoding

com.tuwer.filter.EncodingFileter

encoding

/*

在这里插入图片描述

(2)使用SpringMVC过滤器

CharacterEncodingFilter

encoding

org.springframework.web.filter.CharacterEncodingFilter

encoding

utf-8

encoding

/*

(3)使用通用过滤器
  • GenericEncodingFilter.java

package com.tuwer.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;

public class GenericEncodingFilter implements Filter {

@Override

public void destroy() {

}

@Override

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException, IOException {

//处理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中配置过滤器

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

我的面试宝典:一线互联网大厂Java核心面试题库

以下是我个人的一些做法,希望可以给各位提供一些帮助:

整理了很长一段时间,拿来复习面试刷题非常合适,其中包括了Java基础、异常、集合、并发编程、JVM、Spring全家桶、MyBatis、Redis、数据库、中间件MQ、Dubbo、Linux、Tomcat、ZooKeeper、Netty等等,且还会持续的更新…可star一下!

image

283页的Java进阶核心pdf文档

Java部分:Java基础,集合,并发,多线程,JVM,设计模式

数据结构算法:Java算法,数据结构

开源框架部分:Spring,MyBatis,MVC,netty,tomcat

分布式部分:架构设计,Redis缓存,Zookeeper,kafka,RabbitMQ,负载均衡等

微服务部分:SpringBoot,SpringCloud,Dubbo,Docker

image

还有源码相关的阅读学习

image

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
eper、Netty等等,且还会持续的更新…可star一下!

[外链图片转存中…(img-WOgZkAsm-1712256496179)]

283页的Java进阶核心pdf文档

Java部分:Java基础,集合,并发,多线程,JVM,设计模式

数据结构算法:Java算法,数据结构

开源框架部分:Spring,MyBatis,MVC,netty,tomcat

分布式部分:架构设计,Redis缓存,Zookeeper,kafka,RabbitMQ,负载均衡等

微服务部分:SpringBoot,SpringCloud,Dubbo,Docker

[外链图片转存中…(img-XOlfoTNB-1712256496179)]

还有源码相关的阅读学习

[外链图片转存中…(img-ASsAvoBd-1712256496179)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值