JDK动态代理大家都知道的有spring aop,它的实现就是基于JDK的动态代理,它只能对实现了接口的类实现代理,在程序运行过程中,根据代理的接口来动态生成代理类,如果要使用类的代理,就得使用cglib,我们另一篇文章进行说明。下面直接看一个最简单的实例代码
1:定义一个接口
public interface IUser {
void addUser();
}
2:定义接口的实现
import com.common.service.IUser;
public class UserImpl implements IUser {
public void addUser() {
// 这里是代码逻辑,我们省略,只打印一句话,做为演示
System.out.print("------------add user success----------");
}
}
3:实现代码类
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import com.common.service.IUser;
import com.common.service.impl.UserImpl;
public class MyInvocation implements InvocationHandler {
private Object target;
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
// 加入该对象执行之前的代码逻辑,这里我们只打印一句话,复杂的逻辑也是一样加在这里
System.out.print("对象执行之前的代码逻辑");
// 返回代理对象
Object resultObject = method.invoke(target, args);
// 加入该对象执行之后的代码逻辑,这里我们只打印一句话,复杂的逻辑也是一样加在这里
System.out.print("对象执行之后的代码逻辑");
return resultObject;
}
public MyInvocation(Object target) {
this.target = target;
}
}
4:测试代码是否正常
// 测试方法,也可以写在junit中
public static void main(String[] args) {
// 得到代理对象
MyInvocation myInvocationHandler = new MyInvocation(new UserImpl());
IUser proxy = (IUser) Proxy.newProxyInstance(MyInvocation.class.getClassLoader(),
new Class[] { IUser.class }, myInvocationHandler);
// 调用方法
proxy.addUser();
}
5:查看运行结果
对象执行之前的代码逻辑------------add user success----------对象执行之后的代码逻辑
发现在add方法执行前和执行后打印出来我们执行的代码。这只是一个最简单的实现,类似helloworld,如果有兴趣的话,可以再进行深入研究 。了解一个最简单的实现后再去研究会很有帮助的。