`
wanglei8
  • 浏览: 68225 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

防止出现乱码,J2EE项目统一使用UTF-8编码设置方法

    博客分类:
  • j2ee
阅读更多
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文章版权属于作者,受法律保护。没有作者书面许可不得转载。
19
5
分享到:
评论
17 楼 wanglei8 2011-12-09  
housheng33 写道
非常好


多谢支持
16 楼 housheng33 2011-12-07  
非常好

15 楼 wanglei8 2009-01-12  
aaronluo 写道

应该再详细点,比如如何设置数据库编码为utf8


我使用的是navicat,右键数据库名,选择utf-8编码格式即可
14 楼 wanglei8 2009-01-12  
caiwenhn2008 写道

引用数据库Driver选择UTF-8格式  
请教这是什么意思?


有些mysql driver是区分编码格式的
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
欢迎大家继续讨论,多多指教
12 楼 daoyongyu 2008-11-21  
谢谢楼主分享!
11 楼 wangjeaf 2008-11-19  
曾被乱码问题搞得头大,很有用,顶
10 楼 aaronluo 2008-11-18  
应该再详细点,比如如何设置数据库编码为utf8
9 楼 wujiekangyun 2008-11-13  
引用
jdbc:mysql://localhost:3306/company?useUnicode=true&characterEncoding=utf-8

你确定是UTF-8 不是utf8???
8 楼 justry 2008-11-13  
gbk 使用也不会出现乱码,只要统一字符编码

使用utf-8 你在 sql 状态下怎么查询

鄙视不使用gb
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.数据库

你分析的产生乱码的原因很对
6 楼 chenzengpeng 2008-11-12  
dearshor 写道

caiwenhn2008 写道
引用数据库Driver选择UTF-8格式&amp;nbsp;&amp;nbsp; 请教这是什么意思?我也有此一问

希望LZ解释一下····
5 楼 dearshor 2008-11-12  
caiwenhn2008 写道

引用数据库Driver选择UTF-8格式&nbsp;&nbsp;
请教这是什么意思?

我也有此一问
4 楼 caiwenhn2008 2008-11-12  
引用
数据库Driver选择UTF-8格式  

请教这是什么意思?
3 楼 rubyeye 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.数据库

1 楼 liushilang 2008-11-12  
学习了!,我把这些收录到我的邮箱里,哈哈...绝对尊重原作者

相关推荐

Global site tag (gtag.js) - Google Analytics