一、中文乱码问题
首先要区分是页面乱码、action乱码,还是数据库乱码。
大致的原理是java使用unicode编码-->window使用gbk(gb2312的扩展集)--mysql默认使用utf-8(unicode的一种编码方法),这样转来转去就乱码了
(1)页面中文乱码
对于在页面中显示出现乱码,这个问题比较简单,便是检查你的JSP文件中是不是出现了中文要处理。由于JSP默认的编码格式为“ISO-8859-1”。
jsp代码:<%@ page language="java" import="java.util." pageEncoding="ISO-8859-1">
改成:
jsp代码:<%@ page language="java" import="java.util." pageEncoding="UTF-8"> (推荐)
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ page language="java" import="java.util.*"contentType="text/html; charset=UTF-8" %>
HTML代码:在<head>标签中添加:<metacharset="utf-8">
pageEncoding
在JSP标准的语法中,如果pageEncoding属性存在,那么JSP页面的字符编码方式就由pageEncoding决定,否则就由contentType属性中的charset决定,如果charset也不存在,JSP页面的字符编码方式就采用默认的ISO-8859-1。
pageEncoding是jsp文件本身的编码
contentType的charset是指服务器发送给客户端时的内容编码
(2)传递参数乱码
在form表中中文乱码直接设置constant
1、在struts.xml中设置默认字符集:<constant name="struts.i18n.encoding" value="UTF-8" />
或者 在struts.properties中设置:struts.i18n.encoding=UTF-8
constant要与jsp页面的字符编码一致,可以统一设置为UTF-8,这样乱码问题就可以解决
2、如果使用了spring可以在web.xml中添加字符集过滤器filter,因为拦截有顺序,该过滤器必须放在最前面
<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>
也可以在action中设置字符编码
HttpServletResponseresponse = null;
response =ServletActionContext.getResponse();
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=utf-8");
3、url中文参数乱码以上方法不行,直接设置tomcat中conf文件夹下的server.xml文件。
1和2都只能设置post方式提交数据的编码方式,如果url有中文的话就会有乱码,解决办法是在tomcat的\conf\server文件的
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" URIEncoding="UTF-8"/>
添加 URIEncoding="UTF-8"。如果你正在使用eclipse,记得重启eclipse,把服务器的设置删除,重新设置。
(3)可以自己编写一个字符编码过滤器:(实测效果不好)
http://www.cnblogs.com/guyezhai/p/5556393.html
1、Filter接口:
三个方法说明:
*public void init(FilterConfig filterConfig)throws ServletException//过滤器初始化方法,此方法在过滤器初始化时被调用
*public void doilter(ServletRequest request , ServletResponse response,FilterChain chain)throws IOException, ServletException//对请求进行过滤 处理
*public void destroy();//销毁方法,以便释放资源
2、FilterConfig接口
*public Strng getFilterName();//用于获取过滤器的名字
*public ServletContext getServletContent();//获取Servlet上下文
*public String getInitParameter(String name);//获取过滤器的初始化参数值
*public Enumeration getInitParameterNames();//获取过滤器的所有初始化参数
[5]FilterChain接口
public void doFilter(ServletRequest request request, ServletResponse response)throws IOException , ServletException
3、自定义过滤器
- import java.io.IOException;
- import javax.servlet.Filter;
- import javax.servlet.FilterChain;
- import javax.servlet.FilterConfig;
- import javax.servlet.ServletException;
- import javax.servlet.ServletRequest;
- import javax.servlet.ServletResponse;
- public class CharactorFilter implements Filter {
- // 字符编码
- String encoding = null;
- public void destroy() {
- encoding = null;
- }
- public void doFilter(ServletRequest request, ServletResponse response,
- FilterChain chain) throws IOException, ServletException {
- // 判断字符编码是否为空
- if(encoding != null){
- // 设置request的编码格式
- request.setCharacterEncoding(encoding);
- // 设置response字符编码
- response.setContentType("text/html; charset="+encoding);
- }
- // 传递给下一过滤器
- chain.doFilter(request, response);
- }
- public void init(FilterConfig filterConfig) throws ServletException {
- // 获取初始化参数
- encoding = filterConfig.getInitParameter("encoding");
- }
- }
4、过滤器在web.xml中的配置
- <!-- 声明过滤器 -->
- <filter>
- <!-- 过滤器名称 -->
- <filter-name>CharactorFilter</filter-name>
- <!-- 过滤器的完整类名 -->
- <filter-class>com.lyq.CharactorFilter</filter-class>
- <!-- 初始化参数 -->
- <init-param>
- <!-- 参数名 -->
- <param-name>encoding</param-name>
- <!-- 参数值 -->
- <param-value>UTF-8</param-value>
- </init-param>
- </filter>
- <!-- 过滤器映射 -->
- <filter-mapping>
- <!-- 过滤器名称 -->
- <filter-name>CharactorFilter</filter-name>
- <!-- URL映射 -->
- <url-pattern>/*</url-pattern>
- </filter-mapping>
(4)从数据库取值乱码:比如mysql,确认你的数据库内字符是gbk,并且连接字符串指定了字符编码
<property name="url" value="jdbc:mysql://localhost/database?useUnicode=true&characterEncoding=gbk"></property>
(5)在action中直接使用request.getParameter()时;还是出现乱码。原因分析如下:
1、getParameter()是有带字符参数的。例:
String s =(String)request.getParameter("txt").getBytes("iso-8859-1");
2、String也可以带有字符参数。
String(byte[] bytes, String charsetName)
构造一个新的String,方法是使用指定的字符集解码指定的字节数组。
例:String s = new String("中文","utf-8");
3、综合上述两点,编写一个类来完成此项任务
public classConvertCharacter{
public String Convert(String s){
String result;
byte[] temp ;
try{
temp = s.getBytes("iso-8859-1");
result = new String(temp,"utf-8");
}
return result;
}
}