SpringBoot实现国际化i18n功能

Stella981
• 阅读 596

最近新开发的项目中需要使用到国际化功能,项目是基于SpringBoot来进行开发,借此机会整理一篇关于SpringBoot实现国际化i18n功能的文章,分享给大家。

依赖引入

在Spring Boot的web项目中无需引入其他特殊的配置,默认的web starter中便已经涵盖了所需的基础组件。对应的依赖pom配置如下:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <version>2.2.2.RELEASE</version>
</dependency>

国际化项目结构

这里的项目主要是对外部的api接口,也就是前后端分离的项目。重点介绍后台的国际化配置,以及在接口使用中怎么根据key获取到对应的国际化文案内容。

首先通过整体看一下项目的目录结构:

SpringBoot实现国际化i18n功能

配置解析器

在上面引入了对应的依赖之后,首先用来初始化LocaleResolver类,该类为默认的解析器,用于设置当前会话的默认国际化语言。

/**
 * 配置国际化语言
 *
 **/
@Configuration
public class LocaleConfig {

    /**
     * 默认解析器 其中locale表示默认语言
     */
    @Bean
    public LocaleResolver localeResolver() {
        SessionLocaleResolver localeResolver = new SessionLocaleResolver();
        localeResolver.setDefaultLocale(Locale.CHINA);
        return localeResolver;
    }
}

这里是通过@Configuration注解来实例化配置类,在该配置类中通过@Bean注解的方法注入了创建的SessionLocaleResolver。

配置拦截器

有了解析器,还需要拦截器来对请求的语言参数进行获取,采用默认的LocaleChangeInterceptor作为拦截器来指定切换国际化语言的参数名。比如当请求的url中包含?lang=zh_CN表示读取国际化文件messages_zh_CN.properties。

/**
 * Web相关配置
 **/
@Configuration
public class WebConfig implements WebMvcConfigurer {

    /**
     * 默认拦截器 其中lang表示切换语言的参数名
     *
     */
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        LocaleChangeInterceptor localeInterceptor = new LocaleChangeInterceptor();
        localeInterceptor.setParamName("lang");
        registry.addInterceptor(localeInterceptor);
    }
}

这里通过实现接口WebMvcConfigurer的addInterceptors方法来完成拦截器的初始化和对应参数的设置。

国际化文件

在完成了上面的基础配置之后,就需要定义具体的国际化文件,在文件中定义具体要进行国际化的参数项。

在Spring Boot中国际化文件的名称默认为messages,我们这里就以messages来定义国际化文件。

依次定义messages.properties、messages_en_US.properties、messages_zh_CN.properties、messages_zh_TW.properties。

其中messages.properties表示默认的,里面可以没有值,但必须有这样的一个文件,其他三个分别对应英文、中文、中文繁体。

三个文件的内容依次为:

username=zhangsan

username=张三

username=張三

这里针对国际化文件的放置位置还是有讲究的,如果采用Spring Boot默认的查找路径,那么直接放在resources顶级目录下即可。

但如果想放到其他目录下,比如statistics/i18n/目录下,则需要在application.properties中配置如下:

spring.messages.basename=statistics/i18n/messages

注意前面是没有斜杠的,表示相对路径。而文件名为messages,也不需要添加properties后缀。用过Spring Boot的都知道它会为咱们处理的。

工具类

如果是页面获取国际化内容,则此时后台的操作已经算是完事了,就差前端进行对应的js处理和展示了。我们这里如果只提供api的话,针对api内部分内容的国际化,还是需要根据key来获取对应的值的。

这里就需要一个工具类,来进行处理:

/**
 * 国际化工具类
 **/
@Component
public class MessageUtils {

    private static MessageSource messageSource;

    public MessageUtils(MessageSource messageSource) {
        MessageUtils.messageSource = messageSource;
    }

    /**
     * 获取单个国际化翻译值
     */
    public static String get(String msgKey) {
        try {
            return messageSource.getMessage(msgKey, null, LocaleContextHolder.getLocale());
        } catch (Exception e) {
            return msgKey;
        }
    }

}

主要为了注入MessageSource,该工具上通过@Component进行了实例化。

具体使用

准备好以上内容之后,就可以在Controller层进行使用了,下面直接看代码。

@RestController
@RequestMapping("/i18n")
public class I18nController {

    @RequestMapping("/user")
    public String getUserName() {
        return MessageUtils.get("username");
    }
}

直接定义了请求处理方法,在方法内通过key获得对应的国际化值。

而请求的url格式为:http://localhost:8080/i18n/user?lang=zh_TW

此时页面会展示:

張三

说明国际化的内容已经可以正常使用了。

最后,关注微信公众号“程序新视界”,回复“009”,获取完整源代码。


程序新视界:精彩和成长都不容错过

SpringBoot实现国际化i18n功能

点赞
收藏
评论区
推荐文章
Easter79 Easter79
3年前
springboot2.x配置druid sql监控
  后端接口响应慢,通常我们就需要优化代码和sql,如果项目中使用druid连接池,那么我们可以利用其提供的sql监控功能,来帮助我们快速定位慢sql已经sql执行次数等问题,springboot2之后,durid监控配置变的更简单了,不需要额外的代码,只需要添加配置即可。整个项目配置如下:  依赖<dependency
Easter79 Easter79
3年前
springboot2.0国际化
springboot2.0配合thymeleaf实现页面国际化1\.引入thymeleaf<?xmlversion"1.0"encoding"UTF8"?<projectxmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http:
Easter79 Easter79
3年前
springboot整合mybatis+oracle
第一步认识springboot:springboot是为了解决配置文件多,各个组件不统一的问题,它省去了很多配置文件,同时实现了spring产品的整合。创建springboot项目:通过选择springinit初始化springboot,我们发现它的pom.xml拥有绝大部分的spring所需要的包。第二步_打开项目的结构,
Stella981 Stella981
3年前
SpringBoot Starter大全,都帮你整理好了!
来源:https://www.cnblogs.com/zeussbook/p/11492733.html啥是应用启动器?springboot集成了spring的很多模块,比如tomcat、redis等等。你用springboot搭建项目,只需要在pom.xml引入相关的依赖,和在配置文件中简单的配置就可以使用相应模块了。非常方便,springboo
Stella981 Stella981
3年前
Docker部署SpringBoot项目
SpringBoot项目代码首先构建一个简单的SpringBoot项目,然后给项目添加Docker支持,最后对项目进行部署。在pom.xml中添加SpringBoot依赖,并添加Web支持。<parent<groupIdorg.springfr
Stella981 Stella981
3年前
Spirngboot
一.SpringBootStarter简介Starter是SpringBoot中的一个非常重要的概念,Starter相当于模块,它能将模块所需的依赖整合起来并对模块内的Bean根据环境(条件)进行自动配置。使用者只需要依赖相应功能的Starter,无需做过多的配置和依赖,SpringBoot就能自
Stella981 Stella981
3年前
Myeclipse下使用Maven搭建spring boot2.0项目
现在需要搭建springboot框架,并实现一个HelloWorld的项目,让程序真正运行起来。一、在pom.xml中引入springbootstartparent,spring官方的叫staterpoms,它可以提供dependencymanagement,也就是依赖管理,引入以后在声明其它dependency的时候就不需要version了
Stella981 Stella981
3年前
Ionic6使用组件出现错误:Did you add it to @NgModule.entryComponents
缘由在Ionic6和Angular8项目中使用组件时出现错误:Error:NocomponentfactoryfoundforLoginComponent.Didyouadditto@NgModule.entryComponents?在我的上一篇文章:移动开发:Ionic框架实现注册与登录功能(https:
Easter79 Easter79
3年前
SpringBoot实现国际化i18n功能
最近新开发的项目中需要使用到国际化功能,项目是基于SpringBoot来进行开发,借此机会整理一篇关于SpringBoot实现国际化i18n功能的文章,分享给大家。依赖引入在SpringBoot的web项目中无需引入其他特殊的配置,默认的webstarter中便已经涵盖了所需的基础组件。对应的依赖pom配置如下:<depen
Maven进阶学习指南 | 京东云技术团队
当我们在开发项目时,有时需要用到外部依赖组件,例如当我们需要Json序列化的时候需要用到FastJson组件,我们可以通过下载对应jar包加载到项目中。但当一个大的项目同时需要依赖各种各样的外部服务,就存在着配置繁琐、依赖冲突等问题,因此可以通过maven来完成对应的依赖管理功能。