那是因为你存库进行了编码转换,取出来时也应该进行编码转换才行。我也遇到过这个问题,解决的办法如下:
在jdbcdriver后加上useUnicode=ture&characterEncoding=UTF-8,比如:
jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=library;useUnicode=ture&characterEncoding=UTF-8。目的是将存库时编码设置为utf-8。
写一个filter,代码如下:
package SetCharacterEncodingFilter.java所在的包;
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 destroy()
{
this.encoding = null;
this.filterConfig = null;
}
public void doFilter(ServletRequest request, ServletResponse response,FilterChain chain)
throws IOException, ServletException
{
if (ignore || (request.getCharacterEncoding() == null))
{
// System.out.println(request.getCharacterEncoding());
String encoding = selectEncoding(request);
if (encoding != null)
// System.out.println(encoding);
request.setCharacterEncoding(encoding);
}
chain.doFilter(request, response);
}
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 if (value.equalsIgnoreCase("yes"))
this.ignore = true;
else
this.ignore = false;
}
protected String selectEncoding(ServletRequest request)
{
return (this.encoding);
}
}
找到web.xml,加上:
encoding
org.gridsphere.servlets.SetCharacterEncodingFilter
encoding
utf-8
encoding
encoding
/*
◆◆
评论读取中....
请登录后再发表评论!
◆◆
修改失败,请稍后尝试