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