Spring的两种代理方式

AOP是Spring的重要组成部分,而AOP正是通过代理实现的。如果代理对象实现了接口,则默认使用jdk动态代理,也可强制使用cglib代理,如果未实现接口则只能使用cglib代理。
应用:对一个操作前后事务的开启和提交/回滚

静态代理

public interface Fly {
    void fly();
}

public class Bird implements Fly{

    @Override
    public void fly() {
        // TODO Auto-generated method stub
        System.out.println("飞啊飞~");
    }
}

public class ProxyBird implements Fly{

    //维护一个被代理对象
    Fly bird;
    
    public Fly getBird() {
        return bird;
    }

    public void setBird(Fly bird) {
        this.bird = bird;
    }

    @Override
    public void fly() {
        // TODO Auto-generated method stub
        System.out.println("我代理增强一下你再飞~");
        bird.fly();
    }

}
public class TestBird {
    public static void main(String[] args) {
        Fly bird=new Bird();
        ProxyBird proxyBird=new ProxyBird();
        proxyBird.setBird(bird);
        proxyBird.fly();
    }
}

image.png

JDK动态代理

public interface UserDao {
    void addUser();
}

public class UserDaoImpl implements UserDao{

    @Override
    public void addUser() {
        // TODO Auto-generated method stub
        System.out.println("添加用户~");
    }

}

public class TestJDK {
    public static void main(String[] args) {
        UserDao userDao=new UserDaoImpl();
        UserDao proxy=(UserDao)Proxy.newProxyInstance(userDao.getClass().getClassLoader(), userDao.getClass().getInterfaces(), new InvocationHandler() {
            
            @Override
            public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
                // TODO Auto-generated method stub
                System.out.println("invoke方法前做一些代理");
                method.invoke(userDao, args);
                System.out.println("invoke方法后做一些代理");
                return proxy;
            }
        });
        proxy.addUser();
    }
}

image.png

CGLIB代理

public class UserService {
    
    public void addUser(){
        System.out.println("我不需要接口就可以被代理哦~");
    }
}


public class Testcglb {
    public static void main(String[] args) {
        UserService userService=new UserService();
        Enhancer enhancer = new Enhancer();  
        enhancer.setSuperclass(userService.getClass());  
          
        // 3、设置回调函数  
        enhancer.setCallback(new MethodInterceptor() {  
              
            @Override  
            public Object intercept(Object proxy, Method method, Object[] args,  
                    MethodProxy methodProxy) throws Throwable {  
                if(method.getName().equals("run")){  
                    System.out.println("userService的add方法被拦截了。。。。");  
                    Object invoke = method.invoke(proxy, args);  
                    System.out.println("真实方法拦截之后。。。。");  
                    return invoke;  
                }  
                  
                // 不拦截  
                return method.invoke(proxy, args);  
            }  
        });  
        UserService proxy = (UserService) enhancer.create();  
          
        proxy.run();  
    }
}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,288评论 19 139
  • 关于动态代理和静态代理 当一个对象(客户端)不能或者不想直接引用另一个对象(目标对象),这时可以应用代理模式在这两...
    carway阅读 4,965评论 2 26
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,010评论 6 342
  • 什么是Spring Spring是一个开源的Java EE开发框架。Spring框架的核心功能可以应用在任何Jav...
    jemmm阅读 16,629评论 1 133
  • 明知道没有多大希望,我还是觉得努力,不努力,就什么都没有了。
    3caceb88e40e阅读 133评论 0 0