1:目标对象实现的接口
package com.lovo.spring;
public interface UserManager {
public void addUser(String username,String password);
public void deleteUser(int id);
}
2:目标对象
public class UserManagerImpl implements UserManager {
public void addUser(String username, String password) {
System.out.println("---------userManagerImpl.addUser()--------");
}
public void deleteUser(int id) {
System.out.println("---------userManagerImpl.deleteUser()--------");
}
}
3:创建代理对象
package com.lovo.spring;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
public class SecurityHandler1 implements InvocationHandler {
private Object targetObject;
public Object newProxy(Object targetObject) {
this.targetObject = targetObject;
return Proxy.newProxyInstance(targetObject.getClass().getClassLoader(),
targetObject.getClass().getInterfaces(),
this);
}
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
//安全性检查
checkSecurity();
Object ret = null;
try {
ret = method.invoke(this.targetObject, args);
} catch (Exception e) {
e.printStackTrace();
}
return ret;
}
private void checkSecurity() {
System.out.println("---------安全性检查-------");
}
}
4:测试类
package com.lovo.spring;
public class ClientTest {
public static void main(String[] args) {
SecurityHandler hander = new SecurityHandler();
UserManager userManager =
(UserManager) hander.newProxy(new UserManagerImpl());
// userManager.addUser("xiao", "aa");
userManager.deleteUser(2);
}
}
分析原理:
1:现在是动态代理所以创建的代理对象必须实现 java.lang.reflect.InvocationHandler;
2: private Object targetObject;
把目标对象组合进来
代理模式:定义一个接口 目标对象实现这个接口,而且代理对象一定要把目标对象组合进来。
3: 这个方法的目的是传入目标对象返回代理对象
public Object newProxy(Object targetObject) {
this.targetObject = targetObject;
return Proxy.newProxyInstance(
targetObject.getClass().getClassLoader(),
targetObject.getClass().getInterfaces(),
this);
}
- newProxy(Object targetObject) 传入目标对象返回代理对象
- return Proxy.newProxyIntance(参数1,参数2,参数3);
- 参数1:目标对象的类加载器
- 参数2:目标对象实现的所有接口(数组)
- 参数3:实现了InvocationHandler 这个接口的类
4:
public Object invoke(Object proxy, Method method, Object[] args)
UserManager userManager =
(UserManager) hander.newProxy(new UserManagerImpl());
然后调用这些接口中的方法(其实调用的是接口的实现类的具体方法)
userManager.addUser("xiao", "aa");
userManager.deleteUser(2);
的时候,就会先调用invoke这个拦截方法
重要说明:(自己的理解)
public Object invoke(Object proxy, Method method, Object[] args)
参数1:proxy:就是利用目标对象创建出来的代理对象
参数2:method:jdk帮助文档中的描述:
(对应于在代理实例上调用的接口方法的 Method
实例。
Method
对象的声明类将是在其中声明方法的接口,
该接口可以是代理类赖以继承方法的代理接口的超接口。)
如果要把这个method实例在控制台打印出来可以看到:
public abstract void com.lovo.spring.UserManager.deleteUser(int)
说明:这个deleteUser(int) 就是我们在接口中定义的方法,目标对象实现的方法,也就是我们想要调用的方法,只不过在这里是一个Method实例而已。
参数3:Object[] args
for (int i = 0; i < args.length; i++) {
System.out.println(args[i]);
}
结果:
xiao aa
2
说明:这就是我们 在测试类中调用方法时,传入的参数,在这里被拦截了
5:method.invoke(this.targetObject, args);
利用method这个实例,传入目标对象,就可以执行你要调用的方法
其实这里才是真正的调用你想调用的方法
当然在method.invoke()前后你可以嵌入一些安全 。日志的功能
如上:嵌入的安全检查方法
分享到:
相关推荐
JDK动态代理,关于jdk动态代理的问题!详细的说明!JDK动态代理JDK动态代理
动态代理是使用jdk的反射机制,创建对象的能力, 创建的是代理类的对象。 而不用你创建类文件。不用写java文件。 动态:在程序执行时,调用jdk提供的方法才能创建代理类的对象。jdk动态代理,必须有接口,目标类必须...
对jdk中的动态代理执行过程进行了详细跟踪,并反编译了动态代理调用自动生成的代理类,并对其进行了详细讲解。
JDK动态代理源码下载,动态产生代理,实现对【不同类】,【不同方法】的代理
jdk动态代理技术详解,可以学习一下,不错的
通过一个简单例子来理解JDK动态代理的思想,资源为拷贝的视频讲解的内容。
Jdk动态代理,基于接口的代理示例 InovactionHandler Proxy
java jdk 动态代理 演示demo
AOP之JDK动态代理和CGLib动态代理 ,具体效果和过程看博文 http://blog.csdn.net/evankaka/article/details/45195383
模拟JDK动态代理内部实现
NULL 博文链接:https://jummy.iteye.com/blog/255628
spring aop jdk 动态代理的底层实现解析模拟
JDK动态代理proxy的基本工作原理代码!!
* * * * JDK动态代理 JDK动态代理 JDK动态代理是通过java.lang.reflect.Proxy 类来实现的,我们可以调用Proxy类的newProxyInstance()方法来创建代理对象。对于使用业务接口的类,Spring默认会使用JDK动态代理来实现...
java代理机制 JDK动态代理和cglib代理 详解
java jdk 动态代理演示demo
java静态代理 jdk动态代理 cglib动态代理 代理原理
JAVA动态代理实现Demo(JDK动态代理和CGLIB动态代理)
基于java的jdk动态代理, 比较了静态代理与动态代理的区别,以及动态代理的底层实现,反编译class文件 jdk动态代理和cglib的区别
模拟JDK动态代理