java 过滤器处理中文乱码

数据库连接改为:

jdbc:mysql://localhost:3306/Databasename?useUnicode=true&characterEncoding=UTF-8
在加fileter过滤一下是我用的过滤:


package tool;

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 SetCharacterEncodingFilter implements Filter {
protected String encoding = null;
protected FilterConfig filterConfig = null;
protected boolean ignore = true;


public void init(FilterConfig filterConfig) throws ServletException {
this.filterConfig=filterConfig;
this.encoding=filterConfig.getInitParameter("encoding");
String value=filterConfig.getInitParameter("ignore");
if(value==null)
this.ignore=true;
else if(value.equalsIgnoreCase("true"))
this.ignore=true;
else
this.ignore=false;
}


public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
if (ignore || (request.getCharacterEncoding() == null)) {
String encoding = selectEncoding(request);
if (encoding != null)
request.setCharacterEncoding(encoding);
}
chain.doFilter(request, response);
}


public void destroy() {
this.encoding = null;
this.filterConfig = null;
}


protected String selectEncoding(ServletRequest request) {
return (this.encoding);
}
}

 

在web.xml中增加:


<filter>
<filter-name>Set Character Encoding</filter-name>
<filter-class>
tool.SetCharacterEncodingFilter
</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>Set Character Encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

 

统一采用utf-8的编码。一直这么用没有出过乱码

你可能感兴趣的:(java,Web,mysql,servlet,jdbc)