Java CheckFailedException会去获取message.properties的内容吗

CheckFailedException是 Java 中一个自定义异常类,通常不会自动获取message.properties文件的内容,除非在代码中显式实现了国际化消息加载。

常见的实现方式:

1. 手动加载资源文件

复制代码
public class CheckFailedException extends RuntimeException {
    public CheckFailedException(String messageKey, Locale locale) {
        super(loadMessage(messageKey, locale));
    }
    
    private static String loadMessage(String key, Locale locale) {
        ResourceBundle bundle = ResourceBundle.getBundle("message", locale);
        return bundle.getString(key);
    }
}

2. 通过框架支持(如 Spring)

  • 在 Spring 中,可以使用 MessageSource

    @Component
    public class ExceptionService {
    @Autowired
    private MessageSource messageSource;

    复制代码
      public void throwCheckFailed(String messageKey, Object[] args) {
          String message = messageSource.getMessage(
              messageKey, 
              args, 
              LocaleContextHolder.getLocale()
          );
          throw new CheckFailedException(message);
      }

    }

3. 简单实现(不推荐)

复制代码
// 直接传递消息,不自动获取properties
throw new CheckFailedException("error.user.not.found");

判断是否自动获取:

  1. 查看异常类定义 :检查 CheckFailedException的构造函数

  2. 查看项目配置:检查是否有相关的国际化配置

  3. 查看框架集成:是否使用了 Spring、Quarkus 等框架的消息机制

建议做法:

复制代码
// 推荐:在业务层处理消息,异常只负责携带
public class BusinessService {
    @Autowired
    private MessageSource messageSource;
    
    public void checkSomething() {
        if (conditionFailed) {
            String errorMsg = messageSource.getMessage(
                "check.failed.error", 
                null, 
                Locale.getDefault()
            );
            throw new CheckFailedException(errorMsg);
        }
    }
}

总结 :标准的 CheckFailedException不会自动获取 message.properties,除非你的项目特别实现了这个功能。通常需要在抛出异常前先获取消息文本。

相关推荐
FQNmxDG4S6 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
前端老石人6 小时前
HTML 字符引用完全指南
开发语言·前端·html
matlab_xiaowang6 小时前
Redux 入门:JavaScript 可预测状态管理库
开发语言·javascript·其他·ecmascript
虹科网络安全6 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje7 小时前
Java语法进阶
java·开发语言·jvm
rKWP8gKv77 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫7 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287927 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本7 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
止语Lab7 小时前
从手动到框架:Go DI 演进的三个拐点
开发语言·后端·golang