我有一个运行在j2ee框架上的Spring应用程序。我想使用log4j和Spring实现日志记录。我能够使用自定义注释来记录公共方法。我无法使用自定义注释记录私有方法。有没有人可以参考一下如何实现私有方法的自定义注释。
发布于 2017-11-01 07:30:38
Spring AOP
Spring AOP不支持拦截私有方法。
11. Supported Pointcut Designators
由于Spring框架基于代理的本质,目标对象中的调用根据定义是不会被拦截的。对于JDK代理,只能拦截代理上的公共接口方法调用。使用CGLIB,代理上的公共和受保护的方法调用将被拦截,如果需要,甚至包可见的方法也会被拦截。但是,通过代理进行的常见交互应该始终通过公共签名来设计。请注意,切入点定义通常与任何被拦截的方法相匹配。如果切入点严格意义上是公共的,即使在CGLIB代理场景中,通过代理进行潜在的非公共交互,也需要相应地定义它。如果您的拦截需求包括目标类中的方法调用甚至构造器,请考虑使用Spring驱动的本机AspectJ编织,而不是Spring的基于代理的AOP框架。这构成了具有不同特征的AOP使用的不同模式,因此在做出决定之前,请务必先熟悉编织。
AspectJ源代码编织
您可以通过利用源代码编织来拦截AspectJ私有方法。Here是一个完整的工作示例。
https://stackoverflow.com/questions/47042098
复制相似问题