webwork2在weblogic下和tomcat下的中文问题解决

webwork2在weblogic下和tomcat下的中文问题解决
研究了几天webwork2我的习惯首先关注中文问题解决

中文这方面webwork2比struts更容易解决  不用设置fitler过滤了不错
当然webwork比strust的优势不只是这些

 jsp里都设置gb2312就可以第一

<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %><html><head><title>Untitled Document</title><meta http-equiv="Content-Type" content="text/html; charset=gb2312">

有人说不能加,加了反而乱码,我就没问题第二

在webwork.properties里加上webwork.locale=zh_CNwebwork.i18n.encoding = GB2312

上面做完之后就OK了 页面传值,数据库插入读出都OK了

不过还有需要解决的地方 用过struts的都知道<bean:message>是乱码的webwork也一样,当然这是java程序读文本文件里的中文就是乱码的 解决方法我以前知道的是用native2ascii来转换资源文件,不过转后在编辑就不认识了,修改依次转依次麻烦啊所以我还是选择修改webwork textTag的源码 ,很简单的

找到TextTag.java 然后找到下面这段

if(msg != null) {           
        try{
              msg = new String(msg.getBytes("iso-8859-1"));//加入这行就OK了,这样会影响到国际化,(可以判断如果不是zh_CN就不执行转码,我还没试过)               
            if(getId() == null)               
            {                   
                     pageContext.getOut().write(msg);                
            } else  {           
                     stack.getContext().put(getId(), msg);               
            }           
       } catch(IOException e) { 
               throw new JspException(e);           
      }       
}

struts里也可以这么做的

这样就不用在对资源文件进行native2ascii了

第三

还有会乱码的地方就是fileupload  上传中文名的文件会遇到文件名乱码问题

解决方法试在webwork.properties设置一下

webwork.multipart.parser=pell    //不要用cos

tomcat下中文解决方式和上面相同,不过还需要多加一个URIEncoding="GBK"
位置在server.xml里解决url里有中文出现的乱码
    <Connector className="org.apache.coyote.tomcat4.CoyoteConnector"
port="80"               minProcessors="5" maxProcessors="75"
               enableLookups="true" redirectPort="8443"
               acceptCount="100" debug="0" connectionTimeout="20000"
               useURIValidationHack="false" disableUploadTimeout="true" URIEncoding="GBK"/>

OK 目前我遇到的就这些了

你可能感兴趣的:(webwork2在weblogic下和tomcat下的中文问题解决)