有动态代理和静态代理:
静态代理就是普通的Java继承调用方法。
Spring有俩种动态代理模式:jdk动态代理模式 和 CGLIB动态代理
jdk动态代理模式:
代码实现:
房东出租房子的方法(继承下面出租房子的接口):
package com.bjsxt.proxy1;
public class FangDong implements LetRoom {
@Override
public void zufang() {
System.out.println("出租学院东校区对面和顺小区A401");
}
}
出租房子的方法(接口)
package com.bjsxt.proxy1;
public interface LetRoom {
public void zufang();
}
核心jdk代理(模拟中介卖房)
package com.bjsxt.proxy1;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
public class ZhongJie implements InvocationHandler {
private LetRoom lr;
public void setLr(LetRoom lr) {
this.lr = lr;
}
//执行改方法就会动态产生代理对象
public Object getProxy(){
/**
*
* 参数一:保证类型是ClassLoader
*
* 参数二:接口的class数组
*
* 参数三:参数类型是InvocationHandler即可
*
* */
Object o = Proxy.newProxyInstance(ZhongJie.class.getClassLoader(), new Class[]{LetRoom.class}, this);
return o;
}
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
/**
* proxy:代理对象--中介
*
* method:代理对象中的方法
*
* args:参数--null;
*
* */
System.out.println("收取介绍费100元");
Object invoke = method.invoke(lr, args);
System.out.println("收取管理费500元");
return invoke;
}
}
测试类:
package com.bjsxt.proxy1;
public class Test {
public static void main(String[] args) {
ZhongJie zj=new ZhongJie();
zj.setLr(new FangDong());
LetRoom proxy =(LetRoom) zj.getProxy();
proxy.zufang();
// Util.writeProxyClassToHardDisk("E:/$Proxy11.class",new FangDong().getClass().getInterfaces() );
}
}
测试结果: