Spring代理模式(jdk动态代理模式)

有动态代理和静态代理:

静态代理就是普通的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() );
    }
}

测试结果:

 

 

 

 

 

 

posted @ 2019-12-11 08:56  sakura-yxf  阅读(405)  评论(0)    收藏  举报