Aspect Around Transactional service throw UnexpectedRollbackException

问题描述 投票:0回答:2

我在事务服务中有关于方法的方面。 不幸的是,当我通过服务捕获错误时,会抛出另一个异常。我怎样才能防止这个错误? *我搜索了类似的问题,但似乎没有一个解决方案适合我的情况

@Aspect
@Component
public class ServiceGuard {   
    @Pointcut("execution(* simgenealogy.service.*.*(..))")
    public void persistence() {}

    @Around("persistence()")
    public Object logPersistence(ProceedingJoinPoint joinPoint) { 
        try {
            Object o =  joinPoint.proceed();
            return o;
        } catch (ConstraintViolationException constraintException) {
            // (...)
            return null;
        } catch (Throwable throwable) {
            // (...)
            return null;
        }
    }
}

和错误日志。

2019-07-29 02:10:37.979 ERROR 11300 --- [ion Thread] s.a.g.s.w.ServiceGuard                   :
            Constraint violation: First Name cannot be empty
2019-07-29 02:10:38.023 ERROR 11300 --- [ion Thread] s.a.g.s.w.ServiceGuard                   :
            Constraint violation: Last Name cannot by empty
Exception in thread "JavaFX Application Thread" org.springframework.transaction.UnexpectedRollbackException: Transaction silently rolled back because it has been marked as rollback-only
    at org.springframework.transaction.support.AbstractPlatformTransactionManager.processCommit(AbstractPlatformTransactionManager.java:755)
    at org.springframework.transaction.support.AbstractPlatformTransactionManager.commit(AbstractPlatformTransactionManager.java:714)
    at org.springframework.transaction.interceptor.TransactionAspectSupport.commitTransactionAfterReturning(TransactionAspectSupport.java:534)
    at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:305)
    at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:98)
    at 
spring spring-aop
2个回答
0
投票

你捕获了可能出于某种原因而发生的异常。然后,您只需返回 null 作为先前执行的(通过

proceed()
)方法的结果,可能在预期另一个非空返回值的情况下。

由于您没有提供任何应用程序代码,这是推测性的,但我假设 null 返回值随后被分配给一个应该具有非空值的数据属性(请参阅日志中的约束违规)。更准确地说,您将名字和姓氏设置为 null,这会导致违反约束,这反过来会导致您的事务回滚,因为未设置强制数据字段。

如何解决这个问题?返回名字/姓氏的非空默认值(虽然听起来很奇怪)或者让原始异常升级而不是吞下它们并导致后续问题。

底线:你的异常处理刚刚坏了,需要修复。


0
投票

好的,我找到了解决方案。 @Transactional 也是@Arround 切面。问题出在订购方面。我的 Guard 类实际上并不是围绕 Transaction 的。将@Order(0) 放在 Guard 上,将@Order(1) 放在@Transactional 服务上解决了问题。

© www.soinside.com 2019 - 2024. All rights reserved.