• spring的MVC国际化的设置


    一、基于浏览器语言的国际化配置

    使用Spring的MVC,并且配置中有配置Resource文件

    xml 代码

     

    1. <!-- 资源文件绑定器 -->            
    2. <bean id="messageSource"class="org.springframework.context.support.ResourceBundleMessageSource">                    
    3. <property name="basename" value="message-info" />                  
    4. <property name="useCodeAsDefaultMessage" value="true" />          
    5. </bean>   

     

    <!-- 资源文件绑定器 --> <bean id="messageSource"class="org.springframework.context.support.ResourceBundleMessageSource"> <property name="basename" value="message-info" /> <property name="useCodeAsDefaultMessage" value="true" /> </bean>

    其中,message-info是你的properties文件的通用名。如:我的配置文件叫message-info.properties,message-info_zh_CN.properties等等,只要有了这个配置,然后配置JSP渲染器为JSTL支持的,那么在你的JSP文件中使用fmt标记就可以实现客户浏览器语言国际化了。

    如:<fmt:message key="info.login.title" />

    其中的info.login.title和你的资源文件对应.

    另外一种方式是使用spring自带的标签显示国际化信息,如:

    <spring:message code="main.title" /><br>

    <input type="button" value="<spring:message code="main.title" />"/><br>

    二、基于动态加载的国际化配置

    1、基于请求的国际化配置

    基于请求的国际化配置是指,在当前请求内,国际化配置生效,否则自动以浏览器为主。

    配置方式如下:

    首先配置拦截器

    <!-- 国际化操作 拦截器 必需配置,可以和其它国际化方式通用 -->     

    <mvc:interceptors>
            <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor">
                <property name="paramName">
                    <value>lang</value>
                </property>
            </bean>
        </mvc:interceptors>

    这个配置呢,是不论请求级别的国际化,还是Cookie级别的国际化,再或者Session级别的国际化,都必需有配置这个拦截器,否则会不能使用。

    配好上面的拦截器之后,就将拦截器注入到你的UrlHandlerMapping中,例如:

    Xml代码

     

    1. <bean id="defaultUrlMapping" class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">                   
    2. <property name="interceptors" ref="localeChangeInterceptor" />                   
    3. <property name="order">                            
    4. <value>1</value>                  
    5. </property>         
    6. </bean>  

     

    <bean id="defaultUrlMapping" class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"> <property name="interceptors" ref="localeChangeInterceptor" /> <property name="order"> <value>1</value> </property> </bean>

    这个时候,但凡有了符合UrlMapping的请求,就会被拦截,并且开始配置国际化参数

            <bean id="localeResolver" class="org.springframework.web.servlet.i18n.AcceptHeaderLocaleResolver">        </bean>

    默认的参数名为locale主意大小写。里面放的就是你的提交参数。如:en_US,zh_CN之类的,这个时候,你在页面上加一句<a href="?locale=zh_CN">简体中文</a>

    如果你的资源中,饱含建议中文的配置,那么就会变成你确定的简体中文拉。

    2、基于Session的国际化配置

    拦截器和基于请求的相同

    Session的配置如下:

            <bean id="localeResolver" class="org.springframework.web.servlet.i18n.SessionLocaleResolver"></bean> 

    在你的处理的Controller中,将提交上来的locale字段信息生成真正的Locale对象,然后将对象保存在Session中,默认保存的ID是SessionLocaleResolver.LOCALE_SESSION_ATTRIBUTE_NAME

    这样,当你的Session不过期,那么语言种类始终保持正确的说。我一直是这样子用的,我觉得还是Session的好,老外们用了很满意。

    3、基于Cookie的国际化配置

    这个我就不说了,反正用的不多,至少我做的项目能不用Cookie就不用Cookie,所以,基于Cookie的国际化配置我就不细说了,如果想知道怎么配置,那么下载一个Spring,其中的例子程序就是用Cookie配置的,你自己读代码就OK了。

    三、注意事项

    如果不用默认的浏览器语言国际化方式,那么拦截器一定要配置,如果你有多个UrlMapping,那么就每个都配上拦截器。

    至于配置的LocaleResolver的名字,一定要用上面的配置中的名字localeResolver当然了,这个是默认的名字来的,自己设置成别的也可以,但是就是麻烦,反正我用默认的就感觉不错

    解决问题:

    在前几天引用“Spring 的MVC I18N-国际化相关配置 ”并做了测试,发现 有一问题。程序运行会抛出异常

    “Cannot change HTTP accept header - use a different locale resolution strategy”,根本原因是spring source 做了限制,源码如下

    Java代码

     

    1. public class AcceptHeaderLocaleResolver implements LocaleResolver {   
    2. public Locale resolveLocale(HttpServletRequest request) {    
    3. return request.getLocale();    
    4. }   
    5. public void setLocale(HttpServletRequest request, HttpServletResponse response, Locale locale) {    
    6. throw new UnsupportedOperationException(    
    7.     "Cannot change HTTP accept header - use a different locale resolution strategy");    
    8. }    
    9. }  

     

    public class AcceptHeaderLocaleResolver implements LocaleResolver {public Locale resolveLocale(HttpServletRequest request) { return request.getLocale(); }public void setLocale(HttpServletRequest request, HttpServletResponse response, Locale locale) { throw new UnsupportedOperationException( "Cannot change HTTP accept header - use a different locale resolution strategy"); } }

    请注意上面的类,该类允许继承,所以需要改写setLocale方法,源码示范如下

    Java代码

     

    1. package org.springframework.web.servlet.i18n;   
    2. import java.util.Locale;   
    3. import javax.servlet.http.HttpServletRequest;    
    4. import javax.servlet.http.HttpServletResponse;   
    5. import org.springframework.web.servlet.DispatcherServlet;    
    6. import org.springframework.web.servlet.LocaleResolver;   
    7. public class MyAcceptHeaderLocaleResolver extends AcceptHeaderLocaleResolver {    
    8. private Locale myLocal;    
    9. public Locale resolveLocale(HttpServletRequest request) {    
    10. return myLocal;    
    11. }    
    12. public void setLocale(HttpServletRequest request, HttpServletResponse response, Locale locale) {    
    13. myLocal = locale;    
    14. }    
    15.       
    16. }   

     

    package org.springframework.web.servlet.i18n;import java.util.Locale;import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;import org.springframework.web.servlet.DispatcherServlet; import org.springframework.web.servlet.LocaleResolver;public class MyAcceptHeaderLocaleResolver extends AcceptHeaderLocaleResolver { private Locale myLocal; public Locale resolveLocale(HttpServletRequest request) { return myLocal; } public void setLocale(HttpServletRequest request, HttpServletResponse response, Locale locale) { myLocal = locale; } }

    然后在action-servlet.xml里的设置为

    Xml代码

     

    1. <bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">    
    2. <property name="basename" value="message" />    
    3. </bean>    
    4. <bean id="myViewController" class="org.springframework.web.servlet.mvc.UrlFilenameViewController" />    
    5. <bean id="filenameController" class="org.springframework.web.servlet.mvc.UrlFilenameViewController" />    
    6. <bean id="urlMapping" class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">    
    7. <property name="interceptors" ref="localeChangeInterceptor"/>    
    8. <property name="mappings">    
    9.    <value>    
    10.     chinese.do=filenameController    
    11.     us.do=filenameController    
    12.    </value>    
    13. </property>    
    14. </bean>    
    15. <bean id="defaultHandlerMapping" class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping" />    
    16. <bean id="localeChangeInterceptor" class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" />    
    17. <bean id="localeResolver" class="org.springframework.web.servlet.i18n.MyAcceptHeaderLocaleResolver"/>  
    18. <bean id="viewResolver"    
    19. class="org.springframework.web.servlet.view.InternalResourceViewResolver">    
    20. <property name="viewClass"    
    21.    value="org.springframework.web.servlet.view.JstlView" />    
    22. <property name="prefix" value="/WEB-INF/jsp/" />    
    23. <property name="suffix" value=".jsp" />    
    24. </bean>

    总结一下,有可能由以下原因造成:
    1.如果你使用eclipse创建的工程是class和src分开的,那么资源属性文件一定要放在src目录以内。2.属性文件名的写法:messages_zh_CN.properties (中文)messages_en_US.properties (英文)3.配置messageSource这个bean(注意:一定是messageSource不是messageResource ,这是Spring规定的)<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
    <property name="basenames">
    <list>
    <value>messages</value>
    </list>
    </property>
    </bean>
    4,测试程序要这样写:
      ApplicationContext context = new FileSystemXmlApplicationContext(
      "bean.xml");
      Object[] arguments = new Object[] { "gao kan",
      Calendar.getInstance().getTime() };
      System.out.println(context
      .getMessage("userlogin", arguments, Locale.US));
      System.out.println(context.getMessage("userlogin", arguments,
      Locale.CHINA));注意以上问题,就OK了。

     5. 后台获取当前使用的locale信息: RequestContextUtils.getLocaleResolver(request).resolveLocale(request).getLanguage()


  • 相关阅读:
    条件运算符
    类型
    c#
    打印菱形
    关于隐藏控制器的导航条的问题
    怎么去掉Xcode工程中的某种类型的警告 Implicit conversion loses integer precision: 'NSInteger' (aka 'long') to 'int32
    如何在导航条的button点击变换时,切换对应的控制器
    如何只选择一个
    重写TabBar遇到的按钮不显示的问题
    ASI和AFN的区别
  • 原文地址:https://www.cnblogs.com/pocter/p/3684517.html
Copyright © 2020-2023  润新知