struts 国际化乱码

   差不多半年没复习框架了,都在搞论文和打基础,什么算法和数据结构,还看操作系统啥的,不知道这些

在实际的开发中能用到多少。

   大半年不用struts2连个国际化都不怎么写了,呵呵,按照书上居然弄出了,网上一查马上就搞好了,然而,

居然有出现了中文乱码,真是可恶啊。

 

   下面是解决的办法吧:

 

 1.  首先在struts.xml中配置好国家化资源文件的开头的名字

 

 

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

    <constant name="struts.enable.DynamicMethodInvocation" value="true" />
    <constant name="struts.devMode" value="false" />


    <constant name="struts.custom.i18n.resources" value="message"/>
   
    <package name="default" extends="struts-default" >
        <action name="index" class="endual.iteye.action.Login">
            <result name="success" >hello.jsp</result>
        </action>
    </package>

    <!-- Add packages here -->

</struts>

 

 

 2.资源文件的名字要取好  <constant name="struts.custom.i18n.resources" value="message"/>

 

   这个message就是我们要配置资源文件的开头的名字,你总要告诉框架,我国际化的资源文件的名字是对吧。

然后我们在src下创建两个资源文件,中文一个,英文一个,就是每一种语言一个资源文件

 

   message_zh_CN.properties

 

HelloWorld = 世界你好 !
 

 

   message_en_US.properties

 

HelloWorld = Hello World !

 

 

忘记说了,我们要把资源文件的编码改成支持中文的GBK,什么国家的语言,改成支持什么国家的编码格式吧。要不都无法保存。

 

3.JSP页面的测试:

 

 

<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<%@ taglib prefix="s" uri="/struts-tags" %>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'test.jsp' starting page</title>
    
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->

  </head>
  
  <body>
    
    x<s:property  value="%{getText('HelloWorld')}"/>x
    
   <!--   <s:textfield name="name" label="%{getText(HelloWorld)}"></s:textfield> -->
    
  </body>
</html>
 

 

4.启动tomcat,哎呀,你发现了乱码对吧,呵呵。没关系,很容易解决的。

 

我们要记住了,资源文件中中文要转成asc嘛,貌似拼错了,但是你懂的,就是java语言本身支持的那么编码。

java有工具,在bin目录下,但是,伟大的中国人还是会用代码来解决,比较dos下去打开输入是麻烦的。

 

 

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

5.将中文的字符转成ascii编码,用下面的代码

 

 

package util;  
  
/** 
 * native2ascii.exe Java code implementation. 
 *  
 * @author 
 * @version 1.0 
 */  
public class Native2AsciiUtils {  
  
    /** 
     * prefix of ascii string of native character 
     */  
    private static String PREFIX = "\\u";  
  
    /** 
     * Native to ascii string. It's same as execut native2ascii.exe. 
     *  
     * @param str 
     *            native string 
     * @return ascii string 
     */  
    public static String native2Ascii(String str) {  
        char[] chars = str.toCharArray();  
        StringBuilder sb = new StringBuilder();  
        for (int i = 0; i < chars.length; i++) {  
            sb.append(char2Ascii(chars[i]));  
        }  
        System.out.println(sb.toString()) ;
        return sb.toString();  
    }  
  
    /** 
     * Native character to ascii string. 
     *  
     * @param c 
     *            native character 
     * @return ascii string 
     */  
    private static String char2Ascii(char c) {  
        if (c > 255) {  
            StringBuilder sb = new StringBuilder();  
            sb.append(PREFIX);  
            int code = (c >> 8);  
            String tmp = Integer.toHexString(code);  
            if (tmp.length() == 1) {  
                sb.append("0");  
            }  
            sb.append(tmp);  
            code = (c & 0xFF);  
            tmp = Integer.toHexString(code);  
            if (tmp.length() == 1) {  
                sb.append("0");  
            }  
            sb.append(tmp);  
          
            return sb.toString();  
        } else {  
        	
            return Character.toString(c);  
        }  
    }  
  
    /** 
     * Ascii to native string. It's same as execut native2ascii.exe -reverse. 
     *  
     * @param str 
     *            ascii string 
     * @return native string 
     */  
    public static String ascii2Native(String str) {  
        StringBuilder sb = new StringBuilder();  
        int begin = 0;  
        int index = str.indexOf(PREFIX);  
        while (index != -1) {  
            sb.append(str.substring(begin, index));  
            sb.append(ascii2Char(str.substring(index, index + 6)));  
            begin = index + 6;  
            index = str.indexOf(PREFIX, begin);  
        }  
        sb.append(str.substring(begin));  
        return sb.toString();  
    }  
  
    /** 
     * Ascii to native character. 
     *  
     * @param str 
     *            ascii string 
     * @return native character 
     */  
    private static char ascii2Char(String str) {  
        if (str.length() != 6) {  
            throw new IllegalArgumentException(  
                    "Ascii string of a native character must be 6 character.");  
        }  
        if (!PREFIX.equals(str.substring(0, 2))) {  
            throw new IllegalArgumentException(  
                    "Ascii string of a native character must start with \"\\u\".");  
        }  
        String tmp = str.substring(2, 4);  
        int code = Integer.parseInt(tmp, 16) << 8;  
        tmp = str.substring(4, 6);  
        code += Integer.parseInt(tmp, 16);  
        return (char) code;  
    }  
  
} 
 

 

main类

 

package util;

import java.util.Scanner;

public class MainApp {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		
		Scanner in = new Scanner(System.in) ;
		String str = in.next(); 
		
		//Native2AsciiUtils.ascii2Native(str) ;
		Native2AsciiUtils.native2Ascii(str) ;
		

	}

}
 

 

 

  然后运行程序,把世界你好的中文转成------》》》》》》》》   

 

\u4e16\u754c\u4f60\u597d 

就OK了,然后填写到资源文件夹中。

 

这样中文就不会乱码了。

 

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

假设我们在HelloAction调用了getText那么它会执行以下的操作的

1.查找HelloAction.xx.xx.properties文件中
2.查找HelloAction实现的接口,以及与接口同名的资源文件MyInterface.propreties
3.查找HelloAction的弗雷parentAction的properties文件,文件名为parentAction.properties
4.判断当前HelloAction是否是实现了接口ModelDriven 如果是的,那么就调用getModel方法获得对象
  查找与其同名的资源文件
5.查找当前包下的packaga.paoperties
6.查找到前包的父包,直到顶层包
7.在值栈中查找名为helloworld的属性
8.查找在struts.properties配置的默认的资源文件
9.输出结果
 

 

 

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

 

不知道开发中用到的是什么编码格式,反正GBK是支持英语和中文的,貌似实际的开发中UTF-8用的很多吧

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值