Spring MVC 国际化机制详解(MessageSource 接口体系)

Spring MVC 国际化机制详解(MessageSource 接口体系)

在这里插入图片描述


1. 核心接口与实现类详解
接口/类名描述功能特性适用场景
MessageSource核心接口,定义消息解析能力支持参数化消息(如{0}占位符)所有国际化场景的基础接口
ResourceBundleMessageSourceSpring 官方实现,基于 ResourceBundle支持缓存、自动加载属性文件(如messages_en.properties通用场景(推荐)
StaticMessageSource内存中存储消息(非文件)动态注册消息(如运行时配置)单元测试或动态消息场景
ReloadableResourceBundleMessageSource增强版 ResourceBundleMessageSource支持热加载(无需重启)、编码指定(如encoding=UTF-8需要动态更新消息的生产环境
CacheAwareContextControlMessageSource支持国际化上下文控制(如日期格式)结合 LocaleContextHolder 管理线程级本地化需要复杂本地化控制的场景

2. 完整示例代码
2.1 配置类(Spring Boot)
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.support.ReloadableResourceBundleMessageSource;@Configuration
public class I18nConfig {@Beanpublic ReloadableResourceBundleMessageSource messageSource() {ReloadableResourceBundleMessageSource source = new ReloadableResourceBundleMessageSource();source.setBasename("classpath:i18n/messages"); // 属性文件前缀source.setDefaultEncoding("UTF-8");            // 编码设置source.setCacheSeconds(60);                    // 60秒后重新加载(热更新)return source;}
}
2.2 国际化属性文件
  • messages_en.properties

    greeting=Hello, {0}!
    error=An error occurred: {0}
    
  • messages_zh.properties

    greeting=你好,{0}!
    error=发生错误:{0}
    
2.3 控制器示例
import org.springframework.context.MessageSource;
import org.springframework.web.bind.annotation.*;import java.util.Locale;@RestController
public class I18nController {private final MessageSource messageSource;public I18nController(MessageSource messageSource) {this.messageSource = messageSource;}@GetMapping("/greeting")public String greeting(@RequestHeader(value = "Accept-Language", required = false) Locale locale,@RequestParam String name) {// 根据 locale 解析消息String message = messageSource.getMessage("greeting", new Object[]{name}, locale);return message;}@ExceptionHandler(Exception.class)public String handleException(Exception ex, Locale locale) {return messageSource.getMessage("error", new Object[]{ex.getMessage()}, locale);}
}
2.4 测试请求
# 中文请求
curl -H "Accept-Language: zh-CN" "http://localhost:8080/greeting?name=张三"
# 输出:你好,张三!# 英文请求
curl -H "Accept-Language: en-US" "http://localhost:8080/greeting?name=John"
# 输出:Hello, John!

3. Spring Boot 国际化配置项整理
配置项作用默认值示例
spring.messages.basename消息属性文件前缀(路径)messagesclasspath:i18n/messages
spring.messages.encoding文件编码UTF-8GBK
spring.messages.cache-duration热加载间隔(仅 Reloadable 实现生效)7200s(2小时)60s
spring.http.accept-language.header自定义语言头名称Accept-LanguageX-Language
spring.mvc.locale默认语言由系统 Locale 决定en
spring.mvc.fallback-locale备用语言enzh

4. 关键代码注释说明
  1. ReloadableResourceBundleMessageSource 配置

    source.setCacheSeconds(60); // 60秒后自动重新加载属性文件(无需重启)
    
  2. 控制器中解析消息

    // 参数顺序:消息键、参数数组、当前Locale
    messageSource.getMessage("greeting", new Object[]{name}, locale);
    
  3. 属性文件占位符语法

    greeting=Hello, {0}! // {0} 表示第一个参数(name)
    

5. 总结表格:MessageSource 实现对比
实现类特性适用场景配置复杂度
ResourceBundleMessageSource基础实现,无缓存简单项目
ReloadableResourceBundleMessageSource支持热加载、编码指定需要动态更新的生产环境
StaticMessageSource内存存储,动态注册消息单元测试或动态消息
CacheAwareContextControlMessageSource支持线程级本地化上下文需要复杂本地化控制(如日期格式)

6. 常见问题
  • Q:如何自定义语言切换参数?
    A:通过 @Configuration 注册 LocaleResolver,例如从请求参数 lang 获取语言:

    @Bean
    public LocaleResolver localeResolver() {AcceptHeaderLocaleResolver resolver = new AcceptHeaderLocaleResolver();resolver.setDefaultLocale(Locale.US);resolver.setLanguageAttribute("lang"); // 从请求参数 lang 获取return resolver;
    }
    
  • Q:属性文件路径错误如何排查?
    A:确保文件位于 src/main/resources/i18n/ 目录,名称格式为 messages_{language}.properties


提示:国际化配置建议与前端框架(如 Thymeleaf)结合,通过 <spring:message> 标签直接渲染消息。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/76134.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PyTorch张量范数计算终极指南:从基础到高阶实战

在深度学习领域&#xff0c;张量范数计算是模型正则化、梯度裁剪、特征归一化的核心技术。本文将以20代码实例&#xff0c;深度剖析torch.norm的9大核心用法&#xff0c;并揭示其在Transformer模型中的关键应用场景。 &#x1f680; 快速入门&#xff08;5分钟掌握核心操作&…

荣耀90 GT信息

外观设计 屏幕&#xff1a;采用 6.7 英寸 AMOLED 荣耀绿洲护眼屏&#xff0c;超窄边框设计&#xff0c;其上边框 1.6mm&#xff0c;左右黑边 1.25mm&#xff0c;屏占较高&#xff0c;带来更广阔的视觉体验。屏幕还支持 120Hz 自由刷新率&#xff0c;可根据使用场景自动切换刷新…

【Java中级】11章、枚举 - java引用数据类型,枚举介绍、快速入门,了解枚举类的基本使用方式【1】

文章内容&#xff1a; 自定义实现枚举enum关键字实现枚举 ❤️内容涉及枚举的定义&#xff0c;快速入门&#xff0c;注意事项和小题巩固知识点 &#x1f308; 跟着B站一位老师学习的内部类内容&#xff0c;现写这篇文章为学习内部类的小伙伴提供思路支持&#xff0c;希望可以一…

局域网访问 Redis 方法

局域网访问 Redis 方法 默认情况下&#xff0c;Redis 只允许本机 (127.0.0.1) 访问。如果你想让局域网中的其他设备访问 Redis&#xff0c;需要 修改 Redis 配置&#xff0c;并确保 防火墙放行端口。 方法 1&#xff1a;修改 Redis 配置 1. 修改 redis.conf&#xff08;或 me…

如何应对客户频繁变更需求

如何应对客户频繁变更需求&#xff1f;要点包括&#xff1a; 快速响应、深入沟通、灵活规划、过程记录、风险管控。这些策略既能降低项目失控风险&#xff0c;也能帮助团队在变动环境中保持高效率。其中深入沟通尤为关键&#xff0c;它不仅能够让团队第一时间了解客户意图&…

Set 集合

默认情况下&#xff0c; Scala 使用的是不可变集合&#xff0c; 如果你想使用可变集合&#xff0c; 需要引用 scala.collection.mutable.Set Set 默认是不可变集合&#xff0c;数据无序 数据不可重复 遍历集合 创建可变集合 mutable.Set 打印集合 集合添加元素 向集合中…

最新 OpenHarmony 系统一二级目录整理

我们在学习 OpenHarmony 的时候&#xff0c;如果对系统的目录结构了解&#xff0c;那么无疑会提升自己对 OpenHarmony 更深层次的认识。 于是就有了今天的整理。 首先在此之前&#xff0c;我们要获取源码 获取源码的方式 OpenHarmony 主干代码获取 方式一&#xff08;推荐&am…

STL常用容器整理

STL常用容器操作整理 STL常用容器操作整理&#xff08;string/vector/set/map&#xff09;一、string&#xff08;字符串&#xff09;构造函数元素访问修改操作容量操作子串与查找 二、vector&#xff08;动态数组&#xff09;构造函数元素访问修改操作容量操作 三、set&#x…

Unity 实现伤害跳字

核心组件&#xff1a; Dotween TextMeshPro 过程轨迹如下图&#xff1a; 代码如下&#xff1a; using System.Collections; using System.Collections.Generic; using DG.Tweening; using TMPro; using UnityEngine; using UnityEngine.Pool;public class …

Ubuntu 22.04 AI大模型环境配置及常用工具安装

一、基础环境准备 1.1 系统准备 建议使用 Ubuntu22.04 以下配置皆以 Ubuntu22.04 系统版本为例 1.2 安装git apt-get update && apt-get install git -y1.3 安装 Python 3.9 【建议安装 3.10】&#xff08;安装miniconda或者conda来管理虚拟环境&#xff09; wget …

STM32单片机入门学习——第27节: [9-3] USART串口发送串口发送+接收

写这个文章是用来学习的,记录一下我的学习过程。希望我能一直坚持下去,我只是一个小白,只是想好好学习,我知道这会很难&#xff0c;但我还是想去做&#xff01; 本文写于&#xff1a;2025.04.08 STM32开发板学习——第27节: [9-3] USART串口发送&串口发送接收 前言开发板说…

前端实现docx格式word文件预览,可以兼容原生、vue2、以及uni-app 项目,详细步骤。

上一篇记录了PDF文件预览功能。这一篇记录下docx文件预览。 核心文件 doc.html <script src"./build/polyfill.min.js"></script> <script src"./build/jszip.min.js"></script> <script src"./build/docx-preview.js&…

Java中的ArrayList方法

1. 创建 ArrayList 实例 你可以通过多种方式创建 ArrayList 实例&#xff1a; <JAVA> ArrayList<String> list new ArrayList<>(); // 创建一个空的 ArrayList ArrayList<String> list new ArrayList<>(10); // 创建容量为 10 的 ArrayList …

【anaconda下py】

38 https://repo.anaconda.com/archive/Anaconda3-2020.11-Windows-x86.exe 39 https://repo.anaconda.com/archive/Anaconda3-2022.10-Windows-x86_64.exe 310https://repo.anaconda.com/archive/Anaconda3-2023.03-0-Windows-x86_64.exe 历史列表Index of /archive 远程&…

linux--------------进程控制(下)

一、进程等待 1.1 进程等待必要性 子进程退出后&#xff0c;若父进程不管不顾&#xff0c;可能会产生 “僵尸进程”&#xff0c;进而造成内存泄漏。进程一旦变为僵尸状态&#xff0c;即使使用 kill -9 也无法将其杀死&#xff0c;因为无法杀死一个已死的进程。父进程需要了解…

docker 中跑faster-whisper 教程(1050显卡)

之前我本地机器运行faster-whisper 会报错类似 Could not load library libcudnn_ops_infer.so.8github 上也有类似的情况 &#xff1a;https://github.com/SYSTRAN/faster-whisper/issues/516#issuecomment-2785038635 缺少.so.8 文件&#xff0c;我通过以下方式&#xff0c;…

人大金仓数据库dum文件进行备份数据和恢复数据

逻辑备份命令: sys_dump -U SYSTEM -d problem_dev -Fc -f /db_backup/kingbase/dump/problem_dev/problem_dev20240329.dmp用户:SYSTEM 数据库名:problem_dev 格式:自定义格式(-Fc) 输出文件:/db_backup/kingbase/dump/problem_dev/problem_dev20240329.dmp sys_dump…

Java的Selenium元素定位-xpath

xpath其实就是一个path(路径)&#xff0c;一个描述页面元素位置信息的路径&#xff0c;相当于元素的坐标xpath基于XML文档树状结构&#xff0c;是XML路径语言&#xff0c;用来查询xml文档中的节点。 绝对定位 从根开始找--/(根目录)/html/body/div[2]/div/form/div[5]/button缺…

python-Leetcode 65.搜索旋转排序数组

题目&#xff1a; 整数数组nums按升序排列&#xff0c;数组中的值互不相同 在传递给函数之前&#xff0c;nums在预先未知的某个小标K上进行了旋转&#xff0c;使数组变为[nums[k], nums[k1], ..., nums[n-1], nums[0], nums[1], ..., nums[k-1]]&#xff0c;小标从0开始计数。…

学透Spring Boot — 010. 单元测试和Spring Test

系列文章目录 这是CSDN postnull 博客《学透Spring Boot》系列的一篇&#xff0c;更多文章请移步&#xff1a;Postnull - 学透Spring Boot系列文章 文章目录 系列文章目录前言1. 基本概念UT 单元测试TDD 测试驱动开发UT测试框架Mock框架 3. Spring Test为什么要用Spring Test引…