关闭

中文乱码解决文章摘录

643人阅读 评论(0) 收藏 举报

学了很久的java,接触SSH也有一段时间了,写成博文总是有点懒,最近在整理一些思绪,把SSH一点一滴放进博客里,以备以后改进,再学习。

以我自己的了解,在进行struts开发的过程中,总也是出现很多的乱码问题 ,但归根到底,也只是以下三种情况:

㈠页面显示中文乱码

㈡传递参数中文乱码

㈢国际化资源文件乱码


下面就这三中情况介绍怎么在具体项目中处理这些乱码问题。而对于整体的处理思想,是要统一编码为: UTF-8.(以myeclipse6支持的struts1.3为准)

㈠页面显示中文乱码

      对于在页面中显示出现乱码,这个问题比较简单,便是检查你的JSP文件里是不是出现了中文要处理,因为JSP默认的编码格式为“ISO-8859-1”,当JSP中出现要处理的中文时,其显示就出现乱码了,这种情况一般出现在手写JSP,或修改时。因为在myeclipse6.0中,如果出现了编码错误时,程序不会让你保存,而是会提示你注意编码,这点很好。具体的修改办法是把

Html代码

1.  <%.@ page language="java" import="java.util." pageEncoding="ISO-8859-1">  

<%.@ page language="java" import="java.util." pageEncoding="ISO-8859-1">


改成:

Html代码

1.  <%.@ page language="java" import="java.util." pageEncoding="UTF-8">   

  <%.@ page language="java" import="java.util." pageEncoding="UTF-8">



㈡传递参数中文乱码

         传递参数出现的乱码,参数的内容为中文。比如在struts应用中,简单的一个登录界面中,需要传递的登录名为中文时,你没经处理之前,是会出现乱码传递的,为了让我们能看到显示的乱码,我们在对应的Action类的子类里,修改一下,用System.out把接受到的参数输出,代码如下:

Java代码

1.  public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request,   

2.          HttpServletResponse response) ...{   

3.      DynaActionForm loginForm = (DynaActionForm) form;   

4.    

5.      String username = (String) loginForm.get("username");   

6.      String password = (String) loginForm.get("password");   

7.      System.out.println("username:"+username);   

8.      System.out.println("password:"+password);   

9.      if (username.equals("ivorytower") && password.equals("123456")) ...{   

10.        return mapping.findForward("success");   

11.    }   

12.    return mapping.findForward("fail");   

13.    }  

public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request,

        HttpServletResponse response) ...{

    DynaActionForm loginForm = (DynaActionForm) form;

 

    String username = (String) loginForm.get("username");

    String password = (String) loginForm.get("password");

    System.out.println("username:"+username);

    System.out.println("password:"+password);

    if (username.equals("ivorytower") && password.equals("123456")) ...{

        return mapping.findForward("success");

    }

    return mapping.findForward("fail");

    }



那么当你提交了中文输入后就会出现乱码了。

具体的解决方法:

①修改Tomcat---->conf----->server.xml文件,在修改端口的标签后面加一行代码,如下:

Xml代码

1.  <Connector port="8080" protocol="HTTP/1.1"    

2.                connectionTimeout="20000"    

3.                redirectPort="8443"  URIEncoding="UTF-8"/>  

 <Connector port="8080" protocol="HTTP/1.1"

               connectionTimeout="20000"

               redirectPort="8443"  URIEncoding="UTF-8"/>

注意:如果你在eclipse中使用server这个组件启动工程,你要到eclipse中的server去找server.xml文件,

它在每次启动工程的时候以这个文件区覆盖tom中的server.xml。(否则你在tomcat下改好了,启动的时候,

它有默认改回去了。)
②编写过滤器Filter

Java代码

1.         

2.  import java.io.IOException;   

3.    

4.  import javax.servlet.Filter;   

5.  import javax.servlet.FilterChain;   

6.  import javax.servlet.FilterConfig;   

7.  import javax.servlet.ServletException;   

8.  import javax.servlet.ServletRequest;   

9.  import javax.servlet.ServletResponse;   

10.  

11.public class CharacterEncodingFilter implements Filter ...{   

12.  

13.    @Override  

14.    public void destroy() ...{   

15.    }   

16.  

17.    @Override  

18.    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException,ServletException   {   

19.    request.setCharacterEncoding("utf-8");   

20.    chain.doFilter(request, response);   

21.    }   

22.  

23.    @Override  

24.    public void init(FilterConfig arg0) throws ServletException ...{   

25.    }   

26.  

27.}  

   

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 CharacterEncodingFilter implements Filter ...{

 

    @Override

    public void destroy() ...{

    }

 

    @Override

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException,ServletException   {

    request.setCharacterEncoding("utf-8");

    chain.doFilter(request, response);

    }

 

    @Override

    public void init(FilterConfig arg0) throws ServletException ...{

    }

 

}



  利用过滤器,把requst传递的中文参数都设成“UTF-8”编码。

③修改web.xml文件


    打开项目里的web.xml文件,在前面加上如下代码:

Xml代码

1.        

2.  <filter>  

3.  <filter-name>characterEncoding</filter-name>  

4.  <filter-class>com.v512.example.CharacterEncodingFilter</filter-class>  

5.  </filter>  

6.  <filter-mapping>  

7.  <filter-name>characterEncoding</filter-name>  

8.  <url-pattern>/*</url-pattern>  

9.  </filter-mapping>  

   

 <filter>

 <filter-name>characterEncoding</filter-name>

 <filter-class>com.v512.example.CharacterEncodingFilter</filter-class>

 </filter>

 <filter-mapping>

 <filter-name>characterEncoding</filter-name>

 <url-pattern>/*</url-pattern>

 </filter-mapping>


注意其过滤的URL为“/*”,表示当前的request请求。为了使设置生效,重起tomcat。

㈢国际化资源文件乱码

     ①利用JDK的native2ascii工具进行编码转换

国际化问题,主要是为了处理文件在浏览器上的显示问题,还是以登录界面来说,比如在中文浏览器上,我们要看到中文显示,对应在英文浏览器上要显示英文。那么我们在登录那个界面处理上,就不能直接写上我们的“用户名”“密码”等标识了。就要用标记转换输出了,修改为:

Html代码

1.         

2.  <bean:message key="example.login.username"/>  

   

<bean:message key="example.login.username"/>


  再者,打开项目下的资源配置文件ApplicationResources.properties,依据上面所写key值,设定成我们要的默认值(显示英文),比如

引用

     
#Resource for Parameter 'com.v512.example.struts.ApplicationResources
#Project webexample2
example.login.username=username
example.login.password=password


现在我们动手新建一个资源文件,让其能显示中文,直接Ctrl+C,Ctrl+V。改名为ApplicationResources_zh.properties,代码如下:

引用

      
#Resource for Parameter 'com.v512.example.struts.ApplicationResources
#Project webexample2
example.login.username=用户名
example.login.password=密码


但保存,myeclipse会报错,这时我们需要修改资源文件的编码格式。Windons---->Preferences---->Content Type------>Text----->JavaPropertiesFile,把其Default encoding改为“utf-8”,按“update”更新。这样就能进行保存了。但是当我们进行验证会不是成功时,仍然给我们的是乱码。

不急,我们还得做一项任务,打开DOS窗口,CMD到资源文件所在目录,运用JDK的native2ascii工具把我们新建的资源文件改成另一个名字的资源文件,例如bank.properties。命令如下:

引用

    
>native2ascii -encoding gbk ApplicationResources_zh.properties bank.properties


打开bank.properties资源文件,自动生成的代码如下:

引用

     
#Generated by ResourceBundle Editor (http://eclipse-rbe.sourceforge.net)

example.login.username = \u7528\u6237\u540D
example.login.password = \u5BC6\u7801


然后在myeclipse窗口中,把原来新建ApplicationResources_zh.properties 删除,并把bank.properties改为ApplicationResources_zh.properties (为了方便记忆,管理)。然后重起tomcat或进行reload文件,我们发现乱码问题没有了。

②利用Eclipse ResourceBundle Editor插件工具

      以上我们是利用了JDK的native2ascii工具来处理国际化问题,但在EC中,还有一种更方便的工具专门用来处理编辑java的资源文件国际化乱码问题,即Eclipse ResourceBundle Editor插件工具。安装了这个插件后,我们能进行方便的可视化资源文件编辑。推荐。。

 

 

 

&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&

 

在java开发的时候总会遇到java中文乱码的情况,汉字编码怎样才能正确的选择以及如何正确处理汉字的编码,接下来海浪通过自己的java经验来告知大家应对java中文乱码的妙招。

  第一,要想解决java中文乱码问题就有必要了解一下什么是字符,字符集,编码的概念。

  字符:是文字与符号的总称,包括文字、图形符号、数学符号等。

  字符集:就是一组抽象字符的集合。字符集常常和一种具体的语言文字对应起来,该文字中的所有字符或者大部分常用字符就构成了该文字的字符集,比如英文字符集。繁体汉字字符集、日文汉字字符集等等。

  计算机要处理各种字符,就需要将字符和二进制内码对应起来,这种对应关系就是字符编码: 制定编码首先要确定字符集,并将字符集内的字符排序,然后和二进制数字对应起来。根据字符集内字符的多少,会确定用几个字节来编码。

  每种编码都限定了一个明确的字符集合,叫做被编码过的字符集(Coded Character Set),这是字符集的另外一个含义。通常所说的字符集大多是这个含义。

  第二,要想解决java中文乱码问题也得了解一下我们常用的编码方式:

  ASCII编码是目前计算机中用得最广泛的字符集及其编码。

  ISO8859-1可以表示的是西欧语言。看起来很单一为什么还在使用呢?,由于是单字节编码,和计算机最基础的表示单位一致,所以很多时候,仍旧使用ISO-8859-1编码来表示。 而且在很多协议上,默认使用该编码。

  Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。通常海浪所遇到过多UTF-8这是Unicode编码的实现方式,请一定要加以区分。

  GB2312字集是简体字集;BIG5字集是台湾繁体字集;GBK字集是简繁字集,包括了GB字集、BIG5字集和一些符号

  GB18030是国家制定的一个强制性大字集标准,它的推出使汉字集有了一个统一的标准。

  Linux系统默认使用的是ISO-8859-1编码,Win32系统默认使用的是GB2312编码。

  第三,了解乱码是怎么产生的,如何解决java中文乱码?

  字符在保存时的编码格式如果和要显示的编码格式不一样的话,就会出现乱码问题。海浪在做开发的时候,提倡开发环境编码一致。如页面编码,数据库编码等。

  Java在运行期一律以Unicode来存储字符,这样有利的支持了多语言环境。海浪在开发过程中经常会用到文件读取。Java读文件的时候会用到系统默认的编码来解码文件。所以在用FileInputStream类读取文件可以指定编码读取。

  JSP页面乱码通常只要在页面开始地方用下面代码指定字符集编码即可。如果还不行,那么请用下面这句话来转换 str=new String(str.getBytes("ISO-8859-1"),"页面编码方式");

  JAVA在网络传输中使用的编码是"ISO-8859-1",故在输出时需要进行转化,如:

  String str=new String(str.getBytes("开发环境编码"),"ISO-8859-1");

  经过网络编码后的中文,要正确显示在页面上必须要用类似于

  Stirng str=new String(str.getBytes("ISO-8859-1"),"开发环境编码");     这样的方式来解码

  第四,为了避免不必要的java中文乱码,我们首先要从源头做起。

  什么意思呢?这就是说,我们在项目开发中,首先要让我们开发环境统一编码。比如海浪用的开发环境是Eclipse+Tomcat5.0+SQLServer 2005。Eclipse的项目属性中可以设置项目的编码,可以针对JSP页面的设置统一的编码。

 

 

 

&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&

 

 

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:1279904次
    • 积分:15206
    • 等级:
    • 排名:第772名
    • 原创:320篇
    • 转载:247篇
    • 译文:0篇
    • 评论:105条
    最新评论