中文乱码主要工区分是页面乱码、action乱码和数据库乱码,大致原理是是java使用unicode编码-->window使用gbk(gb2312的扩展集)--mysql默认使用utf-8(unicode的一种编码方法)
1、如果是servlet
request.setCharacterEncoding("gb2312");//请求字符集
response.setContentType("text/html;charset=gb2312");//响应字符集
2、在struts2里面,最好将所有字符都设成utf-8。
<%@ page contentType="text/html; charset=UTF-8"%>
<%@ page pageEncoding="UTF-8" %>
2.1 在jsp页面设定字符编码。
这边有必有说明的是如果是jsp+java bean+servlet的方案,中文乱码很好解决,统一设成gb2312就可以了。
2.2 使用struts框架字符集不能设成gb2312,要改成utf-8。
3、在struts.properties
添加:struts.devMode=false
struts.enable.DynamicMethodInvocation=true
struts.i18n.reload=true
struts.ui.theme=simple
struts.locale=zh_CN
struts.i18n.encoding=UTF-8
struts.serve.static.browserCache=false
struts.url.includeParams=none 其中locale、encoding就是字符集的设定了。
1、如果是servlet
request.setCharacterEncoding("gb2312");//请求字符集
response.setContentType("text/html;charset=gb2312");//响应字符集
2、在struts2里面,最好将所有字符都设成utf-8。
<%@ page contentType="text/html; charset=UTF-8"%>
<%@ page pageEncoding="UTF-8" %>
2.1 在jsp页面设定字符编码。
这边有必有说明的是如果是jsp+java bean+servlet的方案,中文乱码很好解决,统一设成gb2312就可以了。
2.2 使用struts框架字符集不能设成gb2312,要改成utf-8。
3、在struts.properties
添加:struts.devMode=false
struts.enable.DynamicMethodInvocation=true
struts.i18n.reload=true
struts.ui.theme=simple
struts.locale=zh_CN
struts.i18n.encoding=UTF-8
struts.serve.static.browserCache=false
struts.url.includeParams=none 其中locale、encoding就是字符集的设定了。
4. 在web.xml加个filter
<!-- zh-cn encoding --> <filter> <filter-name> struts-cleanup </filter-name> <filter-class> org.apache.struts2.dispatcher.ActionContextCleanUp </filter-class> </filter> <filter-mapping> <filter-name> struts-cleanup</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
5. 第五种方法
String rawQueryStr = request.getQueryString(); String queryStr = java.net.URLDecoder.decode(rawQueryStr,"gbk"); URLENcoder
6.第六种方法
String name = new String(request.getParameter("name").getBytes("ISO-8859-1"),""gbk2312);