基于session的国际化实现方式

基于session的国际化实现方式

  • 原理:使用spring的session bean保存相应的国际化组件。
  1. 配置文件:
  • spring容器配置applicationContext.xml,中添加取得信息的messageSource,放在spring容器而非springmvc容器加载是因为代码中有Service的注解依赖于他
<!-- 国际换的service依赖于他,所以从mvc提到前面 -->
    <bean id="messageSource"
        class="org.springframework.context.support.ResourceBundleMessageSource">
        <!-- 国际化信息所在的文件名 -->
        <property name="basename" value="messages/messages" />
        <!-- 如果在国际化资源文件中找不到对应代码的信息,就用这个代码作为名称 -->
        <property name="useCodeAsDefaultMessage" value="true" />
    </bean>
  1. springmvc容器配置
<mvc:interceptors>
      <!-- 国际化操作拦截器 如果采用基于(请求/Session/Cookie/url)则必需配置 -->
      <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" />
  </mvc:interceptors>
  <!-- 基于session的国际化 -->
  <bean id="localeResolver"
      class="org.springframework.web.servlet.i18n.SessionLocaleResolver" />
  1. spring中的session bean依赖于接口实现,下面是其接口和对应的实现类
public interface I18nSessionService {
  
  public void setRc(RequestContext rc);
  
  public String getMessage(String key); 
  
  public String getMessage(String key,Object info);
  
  public String getMessage(String key,Object...objects);
}
  • 下面注解主要为设置作用域为session,注入messageSource组件,并提供RequestContext用于切换语言配置国际化
@Service
@Scope(value = WebApplicationContext.SCOPE_SESSION,
      proxyMode = ScopedProxyMode.INTERFACES)
public class I18nSessionServiceImpl implements I18nSessionService {

  @Autowired  
  @Qualifier("messageSource")  
  private MessageSource resources;
  //前端设置切换语言是设置
  RequestContext rc ;
  
  public RequestContext getRc() {
      return rc;
  }

  @Override
  public void setRc(RequestContext rc) {
      this.rc = rc;
  }

  @Override
  public String getMessage(String key) {
      // TODO Auto-generated method stub
      if(null != getRc()){
          return getRc().getMessage(key);
      }
      return resources.getMessage(key, null, null);
  }

  @Override
  public String getMessage(String key, Object info) {
      // TODO Auto-generated method stub
      if(null != getRc()){
          return getRc().getMessage(key, new Object[]{info});
      }
      return resources.getMessage(key, new Object[]{info}, null);
  }

  @Override
  public String getMessage(String key, Object... objects) {
              if(null != getRc()){
                  return getRc().getMessage(key, objects);
              }
              return resources.getMessage(key, objects, null);
  }
}
  1. 切换语言的controller用于切换
@Resource
  //注入I18nSessionService后在session作用域中更改local
  private I18nSessionService i18nSessionService;

  @RequestMapping(value = "/turnLanguage", method = { RequestMethod.POST, RequestMethod.GET })
  public void TurnLanguage(HttpServletRequest request,
          @RequestParam(value = "langType", defaultValue = "zh") String langType) {
      if (langType.equals("zh")) {
          Locale locale = new Locale("zh", "CN");
          request.getSession().setAttribute(SessionLocaleResolver.LOCALE_SESSION_ATTRIBUTE_NAME, locale);
      } else if (langType.equals("en")) {
          Locale locale = new Locale("en", "US");
          request.getSession().setAttribute(SessionLocaleResolver.LOCALE_SESSION_ATTRIBUTE_NAME, locale);
      } else {
          request.getSession().setAttribute(SessionLocaleResolver.LOCALE_SESSION_ATTRIBUTE_NAME,
                  LocaleContextHolder.getLocale());
      }
      RequestContext requestContext = new RequestContext(request);
      i18nSessionService.setRc(requestContext);
  }
  1. 使用方式
@Resource
   private I18nSessionService is;
   @RequestMapping(value="/nation",method={RequestMethod.POST,RequestMethod.GET})
   @ResponseBody
   public Result test(HttpServletRequest request){//, @RequestParam(value="langType", defaultValue="zh") String langType
       String msg = is.getMessage("argument.required","userDao");
       return new Result(true, msg, "返回数据");
   }
  • 总结:以上就是基本实现过程,已经可以用了

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏编程坑太多

springboot(17)统一异常处理

1782
来自专栏青青天空树

springboot+security整合3

  这篇讲解如何自定义鉴权过程,实现根据数据库查询出的url和method是否匹配当前请求的url和method来决定有没有权限。security鉴权过程如下:...

2312
来自专栏用户画像

Java 枚举 String-String

913
来自专栏JAVA后端开发

activiti构造属于自己的流程定义

说起actviti,很多人都会说它支持bpmn标准,它的流转都是基于bpmn文件来运行! 但我们在设计流程时,流程定义真的只能是bpmn定义吗?   其实不...

2422
来自专栏Hongten

Struts2 ActionWildcard(通配符配置)约定优于配置

新建web project:struts2_0500_actionwildcard

902
来自专栏大前端开发

理解和使用ES6中的Symbol

ES6中引入了一种新的基础数据类型:Symbol,不过很多开发者可能都不怎么了解它,或者觉得在实际的开发工作中并没有什么场景应用到它,那么今天我们来讲讲这个数据...

2453
来自专栏用户2442861的专栏

HttpEntity的类型及其使用

  代表底层流的基本实体。通常是在http报文中获取的实体。他只有一个空参的构造方法。刚创建时没有内容,长度为负值。需要通过两个方法,把值赋进去。

6141
来自专栏zhisheng

Spring Boot 2.0(七):SpringApplication 深入探索

对于第一个注解 @SpringBootApplication,我已经在博客 Spring Boot 2.0系列文章(六):Spring Boot 2.0中Spr...

1341
来自专栏后端之路

JMockit原理剖析

上篇文章描述了Jmockit的最基本的也是最方便也是最神奇的mock神技单元测试JMockit使用 本篇大概就其原理好好说道。 背景知识 Instrumenta...

6859
来自专栏码匠的流水账

聊聊kafka consumer offset lag的监控

在0.8.2.2版本如下 kafka_2.10-0.8.2.2-sources.jar!/kafka/tools/ConsumerOffsetChecker.s...

2611

扫码关注云+社区