理解:比如说你输入的是HI这个常量,当当前环境是中文是-嗨,当环境改为英文时是-hi。
1、知识概要
一开始,对于i18n来说,我是通过视频观看,但是发现视频讲的是如何实现MessageSource这个接口的方法,但是操作起来还是有点麻烦,后面发现,其实SpringBoot已经对i18n国际化进行了整合。
SpringBoot默认通过AcceptHeaderLocaleResolver解析器来完成对i18n国际化的支持,这个解析器默认使用请求头的Accept-Language字段来判断当前请求所属的环境来对应做出相应的响应。所以这部分不需要亲自去配置,即开箱即用。
2、步骤流程
2.1、创建SpringBoot项目,添加web依赖,将配置文件创建在Resource下
这里就不放图片了,比如说
resource
-static
-messages.properties
-messages_zh_CN.properties
-messages_en_US.properties
但是当你配置文件有相同前缀时,idea就会自动多出一个Resourcce Bundle,其后面会生成以前缀为名字的目录,比如说以上这三个文件都有messages,那么这个目录就是messaages。
解释
messages.properties把它当做一个默认配置,即没有相对应的环境就使用它
messages_zh_CN.properties用于写中文,zh_CN代表中文
messages_en_US.properties用于写英文,en_US代表英文
2.2、为了方便,可以在idea中下载一个插件为Resource Bundle Editor
当然,你也可以选择不下载。这时候可以在这三个配置文件中输入key,比如:
演示
以下是三个文件的配置,这里为了偷懒,就写到同一个草稿里面。
messages.properties
HI=HI
messages_zh_CN.properties
HI=嗨
messages_en_US.properties
HI=hi
配置完成就可以进行使用了。
2.3、在需要的代码地方引入MessageSource
前面说过,SpringBoot已经对i18n做好了配置,它会通过org.springframework.boot.autoconfigure.context.MessageSourceAutoConfiguration自动创建一个MessageSource实例
演示
@RestController
public class TestController {
@Autowired
MessageSource messageSource;
@GetMapping("/test")
public String Test() {
return messageSource.getMessage("HI", null, LocaleContextHolder.getLocale());
}
}
解释
第一个参数:获取变量Key
第二个参数: 占位符,可以进行传递参数,
第三个参数:通过Locale获取当前的语言国际
其实这个接口可以有四个参数,如果加入,其中有一个参数是默认值,就是当该语言环境下key没有对应value,就会使用默认值。
2.4、最后,就是进行测试,这里就不演示了
当然我是对这个接口再一次封装,传递参数一般都为null,语言环境也可以不用改动,一般需要改动的就是key和默认值。同样,这里也只是一个简单的demo,后续会继续更新