21分钟解决struts国际化和中文问题

[入库:2005年8月18日] [更新:2007年3月25日]

本文简介:选择自 cqluojia 的 blog

       当今struts框架的应用已经非常的成熟了,基本的配置我就不多说了,大家上google去搜搜就有一大堆. 最近在一次项目开发中碰到了struts的i18n问题,我来粗略谈谈基本用法,让大家有对struts的国际化问题有一个简略的认识.(注意,以下是在struts开发环境配置好了的情况下实现国际化的步骤,顺便解决了中文问题):

1.  设置所有jsp页面的charset为utf-8.  即在每个jsp页面前加上<%@ page language="java" contenttype="text/html;charset=utf-8" %>.  java是通过unicode实现国际化的,然而unicode和utf-8是一一对应的关系.

2.  jsp页面里面没有硬编码的文字(即页面的文字都是从*.properties资源文件里面读出来的,用<bean:message key="keyword in property file">读取即可.) 资源文件的配置也不多说了,在web.xml里面配配就好. 下面假设英文的资源文件叫applicationresources_en.properties ,中文的源文件叫applicationresources_xx.properties(value都是中文的) . 用jdk自带的native2ascii工具把中文的资源文件里面的中文转化为为用ascii表示的unicode编码, 命令如下:  native2ascii -encoding gbk applicationresources_xx.properties applicationresources_zh.properties . (中文操作系统里面默认是gbk,它是gb2312的扩充集),好了,如果你不用form传中文,不用入库,那么你成功了.打开浏览器在internet选项里面设置一下语言试试. 容易吧,呵呵. 下面的步骤涉及到入库问题.

3.  写一个filter类,一个最简单的代码例子如下:

import java.io.*;
import javax.servlet.*;

public class charsetfilter implements filter{
  private filterconfig config = null;
  private string defaultencode = "utf-8";

  public void init(filterconfig config) throws servletexception {
    this.config = config;
    if(config.getinitparameter("charset")!=null){
        defaultencode=config.getinitparameter("charset");
    }
  }

  public void destroy() {
    this.config = null;
  }

  public void dofilter(servletrequest request, servletresponse response,
                       filterchain chain) throws ioexception, servletexception {
    servletrequest srequest=request;
    srequest.setcharacterencoding(defaultencode);
    chain.dofilter(srequest,response);
  }
}

       然后你需要在web.xml里面设置一下filter,加入下面的即可(注意,如果你是在jbx里面开发,声明filter一定要在声明<servlet>前面,否则会报错,但是用的时候好像又没有问题.)

<filter>
    <filter-name>character encoding</filter-name>
    <filter-class>com.alex.util.charsetencodingfilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>character encoding</filter-name>
    <servlet-name>action</servlet-name>
  </filter-mapping>

4.   接下来是写一个converter类,在入库前调用encode(),出库的时候调用decode()就ok. 下面是一个简单例子:

public class converter {
  public converter() {
  }

  public static string encode(string str) {
    byte temp [];
    temp = str.getbytes();
    try {
      //system.out.println("in before convert: " + str);
      str = new string(temp , "iso-8859-1");
      //system.out.println("in after convert: " + str);
    }
    catch(exception e) {
      system.err.println("convert error: " + e);
    }
    return str;
  }

  public static string decode(string str) {
    byte temp [];
    try {
      //system.out.println("out before convert: " + str);
      temp = str.getbytes("iso-8859-1");
      str = new string(temp,"gbk");
      //system.out.println("out after convert: " + str);
    }
    catch(exception e) {
      system.err.println("convert error: " + e);
    }
    return str;
  }
}

5.  应该都ok了吧,我就这样解决了struts的中文问题和国际化问题. 小弟菜鸟一个,如有错误请高手赐教



本文关键:21分钟解决struts国际化和中文问题
 

本站最佳浏览方式为 分辨率 1024x768 IE 6.0(或更高版本的 IE浏览器)

go top