mysql中文字符集的处理
来源:互联网 发布:linux python开发环境 编辑:程序博客网 时间:2024/05/31 18:32
用mysql administrator把mysql的默认字符集设置成utf8,然后重新启动mysql,可以查看到mysql的字符集都改成了utf8。然后配置了一个filter,也设置为了utf8。
filter:
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 {
// Conditionally select and set the character encoding to be used
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);
}
}
配置:
<filter>
<filter-name>Set Character Encoding</filter-name>
<filter-class>com.ipedo.ipb.web.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
然后用cmd插入了一条中文,但是读出来的时候还是乱码。用jdbc直接插入了一条中文记录,这时读出来的也是正确的。
总结:cmd的mysql客户端的字符集不是uft8的,用mysql官方的Query browser查询的时候是对的,但是Query browser对于插入来说不好操作。
- mysql中文字符集的处理
- Linux下MySql的中文乱码处理-修改字符集
- MySQL的字符集以及中文乱码问题
- ubuntu mysql 中文字符集
- mysql 中文字符集
- mysql中文字符集设置
- mysql中文字符集问题
- mysql字符集支持中文
- mysql 字符集处理
- mysql 字符集处理
- MariaDB中文乱码字符集处理
- MySQL中文查询时的字符集匹配问题的解决
- MYSQL字符集与中文的问题的详细说明
- mysql 5.1 中文字符集问题
- mysql 中文字符集问题解决办法
- MySQL中文查询时的字符集匹配问题
- MySQL 字符集导致SQL连接之后中文乱码的问题!
- mysql修改字符集解决中文乱码的方法
- 关于zhtread编译不过的问题解决办法
- 常用正则表达式
- 几个项目管理软件的比较
- spring资源
- 泛黄的天空
- mysql中文字符集的处理
- javascript中parseInt的问题 - -
- 2005上半年高程考试 下午第一题
- 2005上半年高程考试 下午第二题
- jchq java
- 2005上半年高程考试 下午第三题
- C#下数据库编程(一)
- 2005上半年高程考试 下午第四题
- 2005上半年高程考试 下午第五题