2

我刚刚开始在我的项目中使用 Spring AOP,并且在让 Spring AOP 正常工作方面遇到了一些问题。

我有两个对象,TransportImpl 和 SesssionImpl,我想通过 AOP 进行分析。两个对象(bean)都是通过 Spring 初始化的。两个 bean 都是业务接口(Transport 和 Session)的实现。我可以让应用到 TransportImpl bean 的方面正常工作,但应用到 SessionImpl 的方面不会触发。我可以确认“mySessionMonitor”方面是由 Spring 初始化的,并且 SessionImpl 对象也被初始化,没有任何异常或错误。

我已将 PointCuts 和 Aspect 简化为可能的最基本形式。我希望下面描述的 PointCut sessionOperation在初始化 SessionImpl bean 并调用 init 方法初始化时触发。但这永远不会发生。这里可能出了什么问题?

从配置文件:

<bean id="MyTransport" class="my.app.transport.TransportImpl"   scope="singleton" />                
<bean id="MySession" class="my.app.session.SessionImpl" init-method="initialise" scope="singleton" />

<aop:aspectj-autoproxy proxy-target-class="true">
    <aop:include name="myTransportMonitor" />
    <aop:include name="mySessionMonitor" />
</aop:aspectj-autoproxy>

<bean id="myTransportMonitor" class="my.app.aspects.TransportMonitoringAspect"/>
<bean id="mySessionMonitor"   class="my.app.aspects.SessionMonitoringAspect" />

方面代码

// Aspect monitoring code
@Aspect
public class SessionMonitoringAspect
{
    private Logger fileLogger = Logger.getLogger("myLogger");

    public void initialise()
    {
        fileLogger.info("Initialising SessionMonitoringAspect");
    }

    @Pointcut ("execution (public * *(..))")
    private void anyPublicOperation(){}

    @Pointcut ("within(my.app.session..*)")
    private void inSession(){}

    @Pointcut("anyPublicOperation() && inSession()")
    private void sessionOperation(){}

    @Before("sessionOperation()")
    public void sessionOperationDetected(JoinPoint jp)
    {
        fileLogger.info("Session operation detected - signature: " + jp.getSignature());
    }
}
4

3 回答 3

3

我个人更喜欢将 Aspect 切入点配置放在应用程序上下文中,而您缺少 aop:aspect 中的 ref。

 <bean id="mySessionMonitor"   class="my.app.aspects.SessionMonitoringAspect" />

 <aop:config proxy-target-class="true">
  <aop:aspect ref="mySessionMonitor">
   <aop:pointcut id="around" expression="execution (public * *(..))"/></aop:pointcut>
   <aop:around pointcut-ref="around" method="aroundAdvice"/>
  </aop:aspect>
 </aop:config>
于 2010-08-12T07:01:01.000 回答
0

我希望initialise()方法不是my.app.session.SessionImpl. 如果是这样initialise(),您的 Aspect 方法将不会触发。因为你不能从 bean 类调用方面的方法。否则请附上my.app.session.SessionImpl代码以便详细了解。

于 2010-08-05T05:53:54.843 回答
0

如果您更喜欢基于注释的配置,请参阅我编写的这个示例。您在 XML 配置中只需要<aop:aspectj-autoproxy />.

于 2010-08-19T23:05:56.400 回答