• 基于Session的国际化实现


    其他链接:http://blog.csdn.net/jinwufeiyang/article/details/52338268

    如何将我们网站的其它内容(如菜单、标题等)做国际化处理呢?这就是本篇要将的内容—>国际化。

    在项目的spring.xml文件添加的内容如下

    [html] view plain copy
     
    1. <mvc:interceptors>    
    2. <span style="white-space:pre">    </span><!-- 国际化操作拦截器 如果采用基于(请求/Session/Cookie)则必需配置 -->   
    3.     <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" />    
    4. </mvc:interceptors>  

    在项目中的源文件夹resources中添加myproperties.properties、myproperties_zh_.properties、myproperties_en_.properties三个文件

    下面是jsp页面的一些简单信息如下,仅仅是演示没考虑其他的:

    [html] view plain copy
     
    1. <%@ page language="java" contentType="text/html; charset=UTF-8"  
    2.     pageEncoding="UTF-8"%>  
    3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
    4.   
    5. <html>  
    6. <head>  
    7. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
    8. <title>Insert title here</title>  
    9. </head>  
    10. <%  
    11.     Locale name = (Locale) session.getAttribute("i18nlanguage");  
    12.     ResourceBundle myResourcesBundle = ResourceBundle.getBundle("myproperties",name);  
    13. %>  
    14. <body>  
    15.     <href="${pageContext.request.contextPath}/index/findex.do?langType=en&page=Home">ENG</a> |  
    16.  <href="${pageContext.request.contextPath}/index/findex.do?langType=zh&page=Home"><%=myResourcesBundle.getString("simplified")%></a>  
    17. </body>  
    18. </html>  


    后台Action层代码如下:

    [html] view plain copy
     
     print?
    1. package com.zhidao.oms.index;  
    2.   
    3. import java.util.Locale;  
    4.   
    5. import javax.servlet.http.HttpServletRequest;  
    6.   
    7. import org.springframework.stereotype.Controller;  
    8. import org.springframework.web.bind.annotation.RequestMapping;  
    9. import org.springframework.web.bind.annotation.RequestParam;  
    10.   
    11. @Controller  
    12. @RequestMapping("/index")  
    13. public class IndexAction {  
    14.       
    15.       
    16.     @RequestMapping("/findex")  
    17.     public String Findex(HttpServletRequest request,@RequestParam String langType,String page){  
    18.   
    19.     if(langType.equals("zh")){  
    20.             Locale locale = new Locale("zh", "CN");   
    21.             request.getSession().setAttribute("i18nlanguage",locale);   
    22.         }  
    23.         else if(langType.equals("en")){  
    24.             Locale locale = new Locale("en", "US");   
    25.             request.getSession().setAttribute("i18nlanguage",locale);  
    26.         }else{  
    27.             request.getSession().setAttribute("i18nlanguage",Locale.getDefault());  
    28.         }  
    29.         return "/front/"+page+".jsp";  
    30.     }  
    31.       
    32. }  


    有关的效果图展示大家测试一下就好了!写的不好的地方希望大家批评指正。

  • 相关阅读:
    VMware下Linux配置网络
    前端知识之查漏补缺二
    前端网络基础查漏补缺篇
    简单实现Promise
    前端知识之查漏补缺-1
    git tag
    云服务器安装node环境 mysql nginx
    js动画
    vue原理之双向绑定虚
    js的封装、继承与多态
  • 原文地址:https://www.cnblogs.com/jinwufeiyang/p/5814511.html
Copyright © 2020-2023  润新知