Spring文档建议将@Transactional注释放在具体的类/方法而不是接口上. Stack Overflow多次覆盖了这个原因,例如:
Spring Security @Secured行为不同;大多数文档显示将注释放在界面上.事实上,无论您是使用JDK还是CGLib代理,无论您是注释接口还是具体类,它似乎都有效.
最佳答案
使用JDK代理和CGLib时,最终TransactionInterceptor为@Transactional,MethodSecurityInterceptor为@Secured.
但是这两个MethodInterceptors使用不同的机制在给定的MethodInvocation上找到注释.
使用AnnotationUtils.findAnnotation(Method method,Class方法在SecuredAnnotationSecurityMetadataSource找到@Secured注释,而在AnnotationTransactionAttributeSource帮助SpringTransactionAnnotationParser时发现@Transactional.
看起来AnnotationUtils有更先进的机制来查找注释,搜索接口和声明类层次结构的方法.
您可以使用AnnotationUtils创建自己的TransactionAnnotationParser,这应该为@Transactional启用相同的功能.
AnnotationUtils返回第一个找到的注释,因此处理钻石继承的方式.