没有Aspect J的弹簧2.5

时间:2015-12-30 15:09:41

标签: spring spring-aop spring-2.5

我正在使用spring 2.5开发一个旧项目。应用程序上下文以

我需要使用aop来记录日志记录,我需要记录每个类的方法。 试过这个链接: http://forum.spring.io/forum/spring-projects/aop/4769-apply-jdkregexpmethodpointcut-to-multiple-beans-how.But没有用。 还有一些选择。(但我觉得这会带我去哪里) 另外,我不能使用xsd所以我不能使用aop namespace.i也不能使用方面j

请指导我如何实现这一点,正如我所尝试的那样。和*作为带有切点的模式和bean名称。

1 个答案:

答案 0 :(得分:0)

<强> spring.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean id="debugInterceptor" class="test.DebugInterceptor" />

    <bean id="testBean" class="test.TestBean" />

    <bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
      <property name="beanNames" value="*" />
      <property name="interceptorNames">
        <list>
          <value>debugInterceptor</value>
        </list>
      </property>
    </bean>
</beans>

<强> testBean这个

package test;

public class TestBean {

    public void foo() {
        System.out.println("foo");
    }

    void bar() {
        System.out.println("bar");
    }

}

<强> DebugInterceptor

package test;

import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;

public class DebugInterceptor implements MethodInterceptor {

    public Object invoke(MethodInvocation invocation) throws Throwable {
        System.out.println("Before: invocation=[" + invocation + "]");
        Object rval = invocation.proceed();
        System.out.println("Invocation returned");
        return rval;
    }

}

<强> AopTest

package test;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class AopTest {

    public static void main(String[] args) {
        ApplicationContext ap = new ClassPathXmlApplicationContext("classpath:spring.xml");
        TestBean bean = (TestBean)ap.getBean("testBean");
        bean.foo();
        bean.bar();
    }

}