环境
- Spring 5.1.0.RELEASE
- 开发环境:IDEA
简单配置
注意要引入相应的依赖,MessageSource 在 Spring-Context 中
为了应对在不同地区实现不语言而不用修改源代码,Spring 提供的消息处理功能(i18N)是 MessageSource
简单的说是将你提前准备好的不同地区的不同语言的资源文件准备好,在由浏览器 AcceptLanguage 的 http header 或者其他的方式来确定地区,后端做出相应的处理。
首先要准备好相应的 Java 属性文件 msg.properties
在 项目 resource/message
中
大致路径如下
success={"code":"200","msg":"\u8bf7\u6c42\u6210\u529f"}
failed={"code":"400","msg":"\u8bf7\u6c42\u5931\u8d25"}
解释一下,这里使用的是中文转换后的 Unicode 编码,如果不使用的话传到前台会是乱码
在线字符转换
首先我们要在 配置文件中定义一个 messageSource,代码如下
<!-- 6.MessageSource 国际化 -->
<bean id="messageSource"
class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
<property name="basenames">
<list>
<value>classpath:message/msg</value>
<value>classpath:message/validation_msg</value>
</list>
</property>
<property name="fileEncodings" value="utf-8"/>
<property name="cacheSeconds" value="120"/>
</bean>
- 注意这个 bean 的 id 只能为
messageSource
,写成什么messageResource
都是错误的。- 在 IDEA 中,配置的路径可能可能会报红,但是实际上运行是没有问题的,开始我使用的也是 message.msg 这样的方式来表示路径,但有可能会找不到资源,所以以防万一,还是使用 classpath 的这种方式来配置
当我们定义了一个 messageSource 就要它了
简单使用
解释一下:这个例子是为了快速上手,MessageSource 涉及到的什么地区化,国际化,占位符等方式先暂时忽略,我们的目的是先让程序跑起来,多余的功能慢慢添加。
@Component
public class ResponseTo {
@Autowired
public MessageSource messageSource;
public Map msg(String msg) {
//args 作为在 properties 文件中占位符的实际值,根据 locale 划分的地区找到指定 msg 将 args 填入
//后面的这两个参数是用来配置占位符和国际化的
//这一句是核心,后面的是业务代码,可以暂时不看。
String error = messageSource.getMessage(msg, null, null);
logger.warn("error = {}", error);
ObjectMapper objectMapper = new ObjectMapper();
Map map = null;
try {
map = objectMapper.readValue(error, Map.class);
} catch (IOException e) {
e.printStackTrace();
}
return map;
}
}
当我们在项目的某个地方调用的时候
responseTo.msg("success");
可以看看日志输出了什么
WARN [http-nio-8080-exec-2] 2018-10-16 15:11:19.497 (ResponseTo.java:27) error = {"code":"200","msg":"请求成功"}
这就是 MessageResource
因为网上关于基础的介绍太少,我也花了很多时间去配置第一步,所以第一步成功了看其他的也就更容易