在 Java 中序列化自定义异常中的字段

Pat*_*čin 6 java serialization transient throwable runtimeexception

假设我有我的 custom RuntimeExceptionMyEntityJPA在哪里@Entity

@Getter
public class MyEntityAlreadyExistingException extends RuntimeException {

    private final MyEntity myEntity;

    public MyEntityAlreadyExistingException(MyEntity myEntity) {
        super(MessageFormat.format("MyEntity with name \"{0}\" already exists", myEntity.getName()));
        this.myEntity = myEntity;
    }
}
Run Code Online (Sandbox Code Playgroud)

声纳提示我进行myEntity瞬态或可序列化。

我应该如何处理这种情况?

我不使用任何 RMI,也不使用任何远程处理。它是一个相对简单的 Spring Boot Web 应用程序,带有 JPA。

如果我可以myEntity序列化,我以后可以利用哪些优势?

Ole*_*hov 3

遇到这种情况我该怎么处理呢?

因此,如果您不使用任何 RMI 并且您的应用程序在受保护的环境中运行(并且您想让 Sonar 满意),请将自定义异常类中的所有字段标记为瞬态,或者保持原样。

如果我们谈论的是分布式环境,那么序列化应该非常小心——你的类在序列化后必须具有可预测的行为。在这种情况下,使实例字段成为对象逻辑状态的一部分Serializable,否则 - 将它们标记为瞬态。

PS 为什么声纳会警告你。