Struts+mysql解决显示中文乱码
2009-08-13 12:35
295 查看
这几天被MySQL乱码问题搞死了,我检查了所有页面的编码都没问题,然后在dos里改,改了之后,还是显示character_set_server和character_set_database都是Latin1.然后重新装过,才发现原来在MySql server instance config wizard导向了有一个选项character set里要选utf8。这才把问题解决掉。
今天又用struts做,又是乱码问题,上网查了一下。原来解决方法也挺简单的。就是写一个过滤器,然后在web.xml里配置一下就搞掂了。
过滤器如下:
package com.strutsLogin.util;
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)) {
String encoding = selectEncoding(request);
if (encoding != null)
request.setCharacterEncoding(encoding);
}
// Pass control on to the next filter
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);
}
}//EOC
然后我们在web.xml中加一些配置,就可以了,配置如下:
<filter>
<filter-name>Set Character Encoding</filter-name>
<filter-class>javawebstudio.struts_db.SetCharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>GBK</param-value>
</init-param>
<init-param>
<param-name>ignore</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>Set Character Encoding</filter-name>
<servlet-name>action</servlet-name>
</filter-mapping>
MySQL乱码问题终于算是搞定了。
今天又用struts做,又是乱码问题,上网查了一下。原来解决方法也挺简单的。就是写一个过滤器,然后在web.xml里配置一下就搞掂了。
过滤器如下:
package com.strutsLogin.util;
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)) {
String encoding = selectEncoding(request);
if (encoding != null)
request.setCharacterEncoding(encoding);
}
// Pass control on to the next filter
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);
}
}//EOC
然后我们在web.xml中加一些配置,就可以了,配置如下:
<filter>
<filter-name>Set Character Encoding</filter-name>
<filter-class>javawebstudio.struts_db.SetCharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>GBK</param-value>
</init-param>
<init-param>
<param-name>ignore</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>Set Character Encoding</filter-name>
<servlet-name>action</servlet-name>
</filter-mapping>
MySQL乱码问题终于算是搞定了。
相关文章推荐
- navicat for mysql 显示中文乱码解决办法
- DOS命令行窗口mysql中文显示乱码问题解决方法
- Struts + Spring + Hibernate + Mysql中文乱码问题解决
- python操作mysql中文显示乱码的解决方法
- 解决delphi2007下dbexpress连mysql5时中文显示乱码(文中有可连非默认端口的方法)
- mysql插入表中的中文字符显示为乱码或问号的解决方法
- 关于MySQL的dos客户端中文插入和显示utf-8乱码的解决方法
- mysql查询表中文显示乱码的解决办法
- navicat for mysql学习之道:navicat for mysql 显示中文乱码解决办法
- php mysql 中文乱码解决,数据库显示正常,php调用不正常
- PHP连接MySQL查询结果中文显示乱码解决方法
- 解决mysql无法插入中文数据及插入后显示乱码的问题【亲测图文解说!】
- ubuntu14.04下MYSQL显示中文乱码问题解决方法
- MySQL客户端输出窗口显示中文乱码问题解决办法
- php+mysql中文显示乱码解决
- 【技术贴】java插入mysql中文乱码解决|java插入mysql数据库显示问号?
- Struts + Spring + Hibernate + Mysql中文乱码问题解决
- navicat for mysql 显示中文乱码解决办法
- mysql中文乱码,mysql中文但是网页显示乱码解决办法
- 解决mysql&nbsp;显示中文乱码问题