一、引出問題
有個接口TestServiceInter,有兩個實現方法TestService和Test2Service。他們都有sayHello();
我們的需求是在調用這兩個方法之前,要先完成寫日誌的功能;
二、菜鳥的想法
我在各個實現類的sayHello()方法裏面寫上寫日誌的功能就是了。這樣實現存在的問題:代碼冗餘。當所有實現類都要加上日誌功能的時候,需要寫很多重複代碼。
三、利用AOP前置通知實現此功能
3.1 第一步:我們需要定義一個接口
package com.jdc.aop;/**
}
3.2 第二步:實現接口
public class TestServiceImpl implements TestService { private String name; /**
*** @Description: say hi
* @param ${tags}
* @return ${return_type}
* @throws
* @author jdc
* @date 2018/12/25 1:40 PM
/
@Override public void sayHi(String name ) {
System.out.println(「hi:」 + name);
} public String getName() { return name;
} public void setName(String name) { this.name = name;
}
}
3.3 第三步:實現前置通知(AOP中通知的概念就是實現增強代碼邏輯的,比如這裏的記錄日誌)
/*
<!-- 配置前置通知 --> <bean id="myBeforeAdvice" class="com.jdc.aop.advice.MyBeforeAdvice"/> <!-- 配置被代理對象 --> <bean id="logTestServiceImpl" class="com.jdc.aop.TestServiceImpl"> <property name="name" value="Test"></property> </bean> <!-- 配置代理對象 --> <bean id="proxyFactoryBean" class="org.springframework.aop.framework.ProxyFactoryBean"> <!-- 代理接口集 配置哪些接口要被代理 --> <property name="proxyInterfaces"> <list> <value>com.jdc.aop.TestService</value> </list> </property> <!-- 把通知織入代理對象 --> <property name="interceptorNames"> <value>myBeforeAdvice</value> </property> <!-- 配置被代理的對象 --> <property name="target" ref="logTestServiceImpl"/> </bean>ProxyFactoryBean是一個代理對象,如果我們被代理的對象實現了接口,Spring使用的是jdk動態代理技術實現的動態代理;所以我們要告訴代理對象,我們的哪 些接口需要被代理,然後哪個對象需要被代理,我的增強實現應該怎麼被織入到代理對象(前置,後置,環繞....)
3.5 第五步:寫測試代碼測試
public class TestMain {
public static void main(String[] args) {
ApplicationContext ac = new ClassPathXmlApplicationContext(「beans.xml」);
//獲取代理對象
TestService log = (TestService) ac.getBean(「proxyFactoryBean」);
log.sayHi(「哈哈」);
}
}
注意這裏,我們需要獲取代理對象,而不是目標對象,不然不能調用前置通知的代碼。
文章來自:https://www.itjmd.com/news/show-4314.html