springmvc关于中文乱码的解决

SpringMVC中文乱码解决方案
本文详细介绍了在SpringMVC框架中解决中文乱码的方法,包括页面、传值及数据库层面的处理策略,适用于使用不同服务器环境的开发者。

springmvc关于中文乱码的解决(详解)

JAVAEE的Servlet框架是Web应用中充当中央控制器的角色,采用HTTP协议的请求响应机制实现前端与后台的数据传输和交换,出于网络带宽和安全方面的考虑这些需要传输的数据不是以明文文本的格式进行传输的,需要一定的编码格式进行处理——这就促使MIME类型数据的诞生,实现这种类型的算法叫URLEncoding
JAVAWeb服务器都实现了URLEncoding算法。无论GET还是POST请求都使用这一算法实现对传输数据进行编码。可令人深恶的是,除了英文字母和数字,Web服务器都能自动编码和解码外,其余的的一律由用户自行处理。所以做web应用开发的中国人处理应用的乱码是必不可少的一门技能

A.先查明服务器字符集。tomcat默认使用的字符集是“ISO8859-1”而Weblogic默认是“UTF-8”,所以需要注意跨服务器的代码。
B. 服务器的编码解码机制。编码:服务器在处理客户端的JSP中请求时就先以默认的字符集将请求数据进行编码,然后才将编码后的数据再进行URLencoding;解码:数据传输到后台应用处理程序时,就进行了一次URLdecoder,所以留给后台处理程序的数据是经过应用服务器编码过的数据,这里需要程序员进行处理。
C. 无论请求还是转发(forward),服务器都要进行一次编码

 

根据网络搜素和自身实际经验,总结出以下解决方法

 

1.页面乱码

页面相对是最为容易解决的,往往是在相应的jsp页面或者html页面设置相关的字符集即可

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>  

 

2.传值乱码

1:表单提交controller获得中文参数后乱码解决方案

注意: jsp页面编码设置为UTF-8

form表单提交方式为必须为post,get方式下面spring编码过滤器不起效果

<form action="${ctx}/user/addUser" name="userForm" method="post">  

 

在传值过程中,也是乱码出现的频繁地。

1)在resources文件夹 中,web.xml里添加 字符编码过滤器 characterEncodingFilter

<filter>

<filter-name>characterEncodingFilter</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>

<init-param>

<param-name>forceEncoding</param-name>

<param-value>true</param-value>

</init-param>

</filter>

<filter-mapping>

<filter-name>characterEncodingFilter</filter-name>

<url-pattern>/*</url-pattern>

</filter-mapping>

3) 在Controller 中设置

 

URLDecoder.decode(request.getParameter("test"),"utf-8");

4) 服务器配置(server.xml)

 通过修改tomcat配置文件来解决get乱码
 tomacat对GET和POST请求处理方式是不同的,要处理针对GET请求的编码问题,则需要改tomcat的server.xml配置文件,如  下:

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

注:配置useBodyEncodingForURI=”true”后,可以解决普通get请求的中文乱码问题,但是对于通过ajax发起的get请求中文依然会乱码,请把useBodyEncodingForURI=”true”改为URIEncoding=”UTF-8”即可。

3.存入数据库乱码

 

这个相对就比较复杂,用的mysql,且以mysql来介绍如何来解决这个乱码问题

大家都知道,无论是底层使用的是纯粹的jdbc还是hibernate还是jpa都好,其实本质上都是jdbc,对应的框架只不过在相关的基础上进行特定的封装。所以无论是什么样的技术,都会用到连接到数据库的url。所以url首先是需要检查的

 

数据库 中设置UTF-8 ,数据库连接:

jdbc.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8

 

 

设置request字符集

 

往往从前台传入到对应的controller或者是action之后出现乱码,讲讲我一般的思路是先打印request本身默认的字符集

System.out.println(request.getCharacterEncoding());

 

接着按照情况,如果打印的不是所需要的字符集则设置相应字符集即可

request.setCharacterEncoding("UTF-8");

 

当然某种情况可能还是无法解决这时候用以下这个即可

String str=newString((request.getParameter("bigQuestionTypeName")).getBytes("iso-8859-1"),"utf-8")

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值