中文乱码终极解决之道

Jsp/struts/tapestry/hibernate等中文乱码问题解决

将Java/J2EE系统的统一编码定义为UTF-8。UTF-8编码是一种兼容所有语言的编码方式,惟一比较麻烦的就是要找到应用系统的所有出入口,然后使用UTF-8去“结扎”它。

一个J2EE应用系统需要做下列几步工作:

1、开发和编译代码时指定字符集为UTF-8。JBuilder和Eclipse都可以在项目属性中设置。


2、使用过滤器,如果所有请求都经过一个Servlet控制分配器,那么使用Servlet的filter执行语句,将所有来自浏览器的请求(request)转换为UTF-8,因为浏览器发过来的请求包根据浏览器所在的操作系统编码,可能是各种形式编码。

关键一句:request.setCharacterEncoding("UTF-8")。


3、在JSP头部声明:<%@ page contentType="text/html;charset= UTF-8" %>
 

4、在Jsp的html代码中,声明UTF-8:
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">


5、设定数据库连接方式是UTF-8。例如连接MYSQL时配置URL如下:

jdbc:mysql://localhost:3306/test?useUnicode=true&amp;characterEncoding=UTF-8

注意,上述写法是JBoss的mysql-ds.xml写法,多亏网友提示,在tomcat中&amp;要写成&即可。一般其他数据库都可以通过管理设置设定UTF-8


6、其他和外界交互时能够设定编码时就设定UTF-8,例如读取文件,操作XML等。 

笔者以前在Jsp/Servlet时就采取这个原则,后来使用Struts、Tapestry、EJB、Hibernate、Jdon等框架时,从未被乱码困扰过,可以说适合各种架构。希望本方案供更多初学者分享,减少Java/J2EE的第一个拦路虎,也避免因为采取一些临时解决方案,导致中文问题一直出现在新的技术架构中。

你可能感兴趣的:(jsp,Hibernate,mysql,tapestry,JBuilder)