分享:解决后台接受前台中文信息乱码的问题
有四个方法,记录一下,方便以后自己查找,也方便大家。
首先:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8" contentType="text/html; charset=UTF-8"%>
并且
request.setCharacterEncoding("gb2312");
第二:
配置 server.xml。
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="UTF-8" />
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" URIEncoding="UTF-8"/>
第三:
配置 web.xml
<filter>
<filter-name>setEncoding</filter-name>
<filter-class>com.dinner.filter.CharsetFilters</filter-class>
<init-param>
<param-name>coding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>setEncoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
第四:
工程编码
开发中发现Windows版Eclipse默认Java和Web工程的默认编码方式不那么遂人愿,修改方法如下:
1. Web工程文件编码修改方式
Window -> Preference -> Content types
推荐将Web相关文件的编码都设置为UTF-8
2. Java源文件编码修改方式
Window -> Preference -> Workspace -> Text file encoding
Windows平台默认为GBK,Linux平台默认为UTF-8
经过这四个步骤,肯定能解决的。
连接来源:http://blog.sina.com.cn/s/blog_62aab2760100l1hx.html
------解决方案--------------------接分,谢谢分享。
------解决方案--------------------------解决方案--------------------谢谢楼主分享!顺便问一下,什么时候需要进行页面编码?比如从ISO-8859-1转换成ustf-8或者GB2312
------解决方案--------------------mark 日后查看
------解决方案--------------------刚做一个编码解码的程序,这帖子留着
------解决方案--------------------
utf-8是使用3个字节来表示一个中文字符,而GB2312或者GBK是使用2个字节表示一个中文字符,而ISO-8859-1使用一个字节来表示一个字符,在传输的过程中是用的是iso8859-1,如果接收方是其他编码的时候,则要在接收的时候要设置编码,当然你服务端向客户端传输中文的时候也要设置编码。
一般jsp页面直接在charset中设置编码方式即可