Java异常国际化核心是分离消息键与文案,异常仅持key(如user.not.found),文案由messages.properties等资源文件按Locale动态加载,结合ResourceBundle与MessageFormat实现延迟解析,并可通过Spring的ResourceBundleMessageSource简化集成。
Java里异常信息国际化,核心是把“错在哪”和“怎么说”分开——异常只携带一个消息键(如 user.not.found),具体提示文本交给外部资源文件按语言动态加载。
在 src/main/resources 下创建标准命名的 .properties 文件:
所有文件使用相同 key,例如:
user.not.found=用户不存在 user.not.found=User not found
中文需转为 Unicode(IDE 通常自动处理,或用 native2ascii 工具)。
不直接存字符串,而是持有一个 key 和可选参数:
这样异常本身不绑定语言,也不硬编码文案。
推荐封装工具类统一加载:

i18n/messages_*.properties)Order {0} already exists
避免每次手动 new ResourceBundle,也别在异常构造时就解析——延迟到真正需要展示时再做。
若用 Spring Boot,直接配置 ResourceBundleMessageSource Bean:
exceptions_zh_CN.properties 等@ControllerAdvice)中注入 MessageSource
messageSource.getMessage(key, args, locale) 获取最终文案这种方式解耦干净,支持默认回退(找不到 key 时用英文或兜底文案),也便于测试和维护。