Spring MessageResource

环境

  • Spring 5.1.0.RELEASE
  • 开发环境:IDEA

简单配置

注意要引入相应的依赖,MessageSource 在 Spring-Context 中

为了应对在不同地区实现不语言而不用修改源代码,Spring 提供的消息处理功能(i18N)是 MessageSource

简单的说是将你提前准备好的不同地区的不同语言的资源文件准备好,在由浏览器 AcceptLanguage 的 http header 或者其他的方式来确定地区,后端做出相应的处理。

首先要准备好相应的 Java 属性文件 msg.properties 在 项目 resource/message
大致路径如下

Spring MessageResource_第1张图片
Java 属性文件路径

success={"code":"200","msg":"\u8bf7\u6c42\u6210\u529f"}
failed={"code":"400","msg":"\u8bf7\u6c42\u5931\u8d25"}

解释一下,这里使用的是中文转换后的 Unicode 编码,如果不使用的话传到前台会是乱码
在线字符转换

首先我们要在 配置文件中定义一个 messageSource,代码如下

    
    
        
            
                classpath:message/msg
                classpath:message/validation_msg
            
        
        
        
    
  • 注意这个 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

因为网上关于基础的介绍太少,我也花了很多时间去配置第一步,所以第一步成功了看其他的也就更容易

更多拓展资料

你可能感兴趣的:(Spring MessageResource)