1.数据库建立为UTF-8格式
2.项目右键属性为UTF-8格式
3.所有页面申明为UTF-8
4.JDBC URL设为:UTF-8
jdbc:mysql://localhost:3306/company?useUnicode=true&characterEncoding=utf-8
5.数据库Driver选择UTF-8格式
6.Tomcat编码改成UTF-8
在server.xml里面增加URIEncoding="UTF-8"
<Connector port="8080" maxHttpHeaderSize="8192" maxThreads="150" minSpareThreads="25" maxSpareThreads="75" enableLookups="false" redirectPort="8443" acceptCount="100" connectionTimeout="20000" disableUploadTimeout="true" URIEncoding="UTF-8" />
7.加编码过滤器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 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; } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // TODO 自动生成方法存根 if (ignore || (request.getCharacterEncoding() == null)) { String encoding = selectEncoding(request); if (encoding != null) request.setCharacterEncoding(encoding); } chain.doFilter(request, response); } public void destroy() { // TODO 自动生成方法存根 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>com.yourcompany.util.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>
声明:JavaEye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
1 楼 liushilang 2008-11-12
学习了!,我把这些收录到我的邮箱里,哈哈...绝对尊重原作者
2 楼 xyh 2008-11-12
楼主MySQL使用的哪个版本,5.0的乱码一直不得解决,只好new String(request.getParameter("ISO-8859-1"),"UTF-8")。
6.0的舒服多了,写个Filter集中拦截处理请求的字符编码,数据库的Charset为gb2312,我们不搞国际化。
URL不加characterEncoding=utf-8也行。
我觉得乱码一般来自:
1.请求
2.响应
3.页面
4.数据库
6.0的舒服多了,写个Filter集中拦截处理请求的字符编码,数据库的Charset为gb2312,我们不搞国际化。
URL不加characterEncoding=utf-8也行。
我觉得乱码一般来自:
1.请求
2.响应
3.页面
4.数据库
3 楼 rubyeye 2008-11-12
做了不少重复的工作,项目最好不要依赖应用服务器
4 楼 caiwenhn2008 2008-11-12
引用
数据库Driver选择UTF-8格式
请教这是什么意思?
5 楼 dearshor 2008-11-12
caiwenhn2008 写道
引用数据库Driver选择UTF-8格式
请教这是什么意思?
我也有此一问
6 楼 chenzengpeng 2008-11-12
dearshor 写道
caiwenhn2008 写道
引用数据库Driver选择UTF-8格式&nbsp;&nbsp; 请教这是什么意思?我也有此一问
希望LZ解释一下····
7 楼 daweiangel 2008-11-12
xyh 写道
楼主MySQL使用的哪个版本,5.0的乱码一直不得解决,只好new String(request.getParameter("ISO-8859-1"),"UTF-8")。 6.0的舒服多了,写个Filter集中拦截处理请求的字符编码,数据库的Charset为gb2312,我们不搞国际化。 URL不加characterEncoding=utf-8也行。 我觉得乱码一般来自: 1.请求 2.响应 3.页面 4.数据库
你分析的产生乱码的原因很对
8 楼 justry 2008-11-13
gbk 使用也不会出现乱码,只要统一字符编码
使用utf-8 你在 sql 状态下怎么查询
鄙视不使用gb
使用utf-8 你在 sql 状态下怎么查询
鄙视不使用gb
9 楼 wujiekangyun 2008-11-13
引用
jdbc:mysql://localhost:3306/company?useUnicode=true&characterEncoding=utf-8
你确定是UTF-8 不是utf8???
10 楼 aaronluo 2008-11-18
应该再详细点,比如如何设置数据库编码为utf8
11 楼 wangjeaf 2008-11-19
曾被乱码问题搞得头大,很有用,顶
12 楼 daoyongyu 2008-11-21
谢谢楼主分享!
13 楼 wanglei8 2009-01-12
xyh 写道
楼主MySQL使用的哪个版本,5.0的乱码一直不得解决,只好new String(request.getParameter("ISO-8859-1"),"UTF-8")。
6.0的舒服多了,写个Filter集中拦截处理请求的字符编码,数据库的Charset为gb2312,我们不搞国际化。
URL不加characterEncoding=utf-8也行。
我觉得乱码一般来自:
1.请求
2.响应
3.页面
4.数据库
我的mysql是mysql-5.0.45-win32,使用我的方法没有再出现过乱码情况
如果你不使用中文作为请求参数的话,可以URL不加characterEncoding=utf-8
我们做的项目是global project需要国际化,所以使用utf-8
欢迎大家继续讨论,多多指教
14 楼 wanglei8 2009-01-12
caiwenhn2008 写道
引用数据库Driver选择UTF-8格式??
请教这是什么意思?
有些mysql driver是区分编码格式的
15 楼 wanglei8 2009-01-12
aaronluo 写道
应该再详细点,比如如何设置数据库编码为utf8
我使用的是navicat,右键数据库名,选择utf-8编码格式即可
16 楼 housheng33 2011-12-07
非常好
![](/images/smiles/icon_idea.gif)
17 楼 wanglei8 2011-12-09
housheng33 写道
非常好
![](/images/smiles/icon_idea.gif)
多谢支持