IUserDao.java
public interface IUserDao { public boolean addUser(); }
UserDaoImpl.java
public class UserDaoImpl implements IUserDao { @Override public boolean addUser() { System.out.println("UserDaoImpl addUser..."); return false; } }
LogUtil.java
public class LogUtil { public void addLog() { System.out.println("LogUtil addLog..."); } }
applicationContext.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" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd"> <aop:aspectj-autoproxy /> <bean name="userdao" class="cn.lichen.dao.impl.UserDaoImpl"></bean> <bean name="log" class="cn.lichen.util.LogUtil"></bean> <aop:config> <aop:pointcut expression="execution(* cn.lichen.dao.*.*(..))" id="pointcut"/> <aop:aspect id="logUtil" ref="log"> <aop:before method="addLog" pointcut-ref="pointcut"/> </aop:aspect> </aop:config> </beans>
UserDaoImplTest.java
public class UserDaoImplTest { @Test public void testAddUser() { ApplicationContext factory = new ClassPathXmlApplicationContext("applicationContext.xml"); IUserDao dao = (IUserDao) factory.getBean("userdao"); dao.addUser(); } }
lib包不变。
虽然可以通过编程的方式织入切面,但是一般情况下,我们还是使用spring的配置自动完成创建代理织入切面的工作。
通过aop命名空间的<aop:aspectj-autoproxy />声明自动为spring容器中那些配置@aspectJ切面的bean创建代理,织入切面。当然,spring
在内部依旧采用AnnotationAwareAspectJAutoProxyCreator进行自动代理的创建工作,但具体实现的细节已经被<aop:aspectj-autoproxy />隐藏起来了
<aop:aspectj-autoproxy />有一个proxy-target-class属性,默认为false,表示使用jdk动态代理织入增强,当配为<aop:aspectj-autoproxy
poxy-target-class="true"/>时,表示使用CGLib动态代理技术织入增强。不过即使proxy-target-class设置为false,如果目标类没有声明接口,则spring将自动使用CGLib动态代理。
参考:http://www.blogjava.net/fanjs2000/archive/2012/04/25/376552.html