struts2中文乱码解决方法

来源:互联网 发布:java毕业设计题目 编辑:程序博客网 时间:2024/05/15 22:57

解决方法如下:

   1. struts2里面,最好将所有字符都设成utf-8

<%@ page contentType="text/html; charset=UTF-8"%>
<%@ page pageEncoding="UTF-8" %>

   1.1 jsp页面设定字符编码。这边有必有说明的是如果是jsp+java bean+servlet的方案,中文乱码很好解决,统一设成gb2312就可以了。

    1.2 使用struts框架字符集不能设成gb2312,要改成utf-8

   2. 在struts.properties 添加:

struts.devMode=false
struts.enable.DynamicMethodInvocation=true
struts.i18n.reload=true
struts.ui.theme=simple

struts.locale=zh_CN
struts.i18n.encoding=UTF-8

struts.serve.static.browserCache=false
struts.url.includeParams=none

其中localeencoding就是字符集的设定了。

   3. web.xml加个filter

  <!-- zh-cn encoding -->
    <filter>
        <filter-name>struts-cleanup</filter-name>
        <filter-class>
            org.apache.struts2.dispatcher.ActionContextCleanUp
        </filter-class>
    </filter>  
    <filter-mapping>
        <filter-name>struts-cleanup</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

      跟上述方法,类似还有在action中设定字符编符.


   HttpServletResponse response = null;
   response = ServletActionContext.getResponse();
   request.setCharacterEncoding("utf-8");
   response.setContentType("text/html;charset=utf-8");

 

 

    通过上述方法,基本就可以搞定中文乱码的问题了。当然,也有例外(web server的版本/数据库的版本等等)。象在我的一个项目碰到一个中文乱码,tomcate5.5是会乱码的,而在tomcate6中就不会。这边就涉及到tomcate connector字符的设置了。

    <Connector port="80" maxHttpHeaderSize="8192"
               maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
               enableLookups="false" redirectPort="8443" acceptCount="100"
               connectionTimeout="20000" disableUploadTimeout="true" URIEncoding="GBK"  />

 

--------------------------------------------------------------------

  后记之一:在使用struts2时,仍是遇到一种乱码。后来调试才发现,struts2web.xml配置是有顺序的

   web.xmlEncodingFilter的位置应该在Struts2FilterDispatcher之前,因为要先调整字符集,然后进入Action

  按照Struts2APIfilter的顺序是
struts-cleanup filter
SiteMesh filter
FilterDispatcher

--------------------------------------------------------------------

   后记之二:这个方法是下下策了,只有在前面的方法都无效时才使用。

action中直接使用request.getParameter();还是出现乱码。原因分析如下:

   1getParameter()是有带字符参数的。例:

String s = (String)request.getParameter("txt").getBytes("iso-8859-1");

   2String也可以带有字符参数。

String(byte[] bytes, String charsetName) 
构造一个新的 String,方法是使用指定的字符集解码指定的字节数组。

例:String s = new String("中文","utf-8");

   3、综合上述两点,编写一个类来完成此项任务

   public class ConvertCharacter{

        public String Convert(String s){

            String result;

            byte[] temp ;

            try{

                temp = s.getBytes("iso-8859-1");

                result =  new String(temp,"utf-8");

            }

            return result;

        }

   }

 

 

原创粉丝点击