-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Expand file tree
/
Copy pathJdkDynamicAopProxy.java
More file actions
48 lines (42 loc) · 1.56 KB
/
JdkDynamicAopProxy.java
File metadata and controls
48 lines (42 loc) · 1.56 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package com.ysj.tinySpring.aop;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import org.aopalliance.intercept.MethodInterceptor;
/**
* 一个基于JDK的动态代理
* 只能针对实现了接口的类生成代理。于是我们就有了基本的织入功能。
* 注意:实现了InvocationHandler接口,可以通过重写invoke方法进行控制访问
*
*/
public class JdkDynamicAopProxy extends AbstractAopProxy implements InvocationHandler {
public JdkDynamicAopProxy(AdvisedSupport advised) {
super(advised);
}
/**
* 获取代理对象
*/
@Override
public Object getProxy() {
return Proxy.newProxyInstance(getClass().getClassLoader(),
advised.getTargetSource().getInterfaces(),
this);
}
/**
* 控制访问
*/
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
// 从AdvisedSupport里获取方法拦截器
MethodInterceptor methodInterceptor = advised.getMethodInterceptor();
// 如果方法匹配器存在,且匹配该对象的该方法匹配成功,则调用用户提供的方法拦截器的invoke方法
if (advised.getMethodMatcher() == null
|| advised.getMethodMatcher().matches(method, advised.getTargetSource().getTarget().getClass())) {
return methodInterceptor.invoke(new ReflectiveMethodInvocation(advised.getTargetSource().getTarget(),
method, args));
} else {
// 否则的话还是调用原对象的相关方法
return method.invoke(advised.getTargetSource().getTarget(), args);
}
}
}