强悍的Spring之AOP CGLIB实现


1、什么是CGLIB

CGLIB(Code Generator Library)是一个强大的、高性能的代码生成库。其被广泛应用于AOP框架(Spring、dynaop)中,用以提供方法拦截操作。Hibernate作为一个比较受欢迎的ORM框架,同样使用CGLIB来代理单端(多对一和一对一)关联。

2、为什么使用CGLIB

CGLIB代理主要通过对字节码的操作,为对象引入间接级别,以控制对象的访问。我们知道Java中有一个动态代理也是做这个事情的,那我们为什么不直接使用Java动态代理,而要使用CGLIB呢?答案是CGLIB相比于JDK动态代理更加强大,JDK动态代理虽然简单易用,但是其有一个致命缺陷是,只能对接口进行代理。如果要代理的类为一个普通类、没有接口,那么Java动态代理就没法使用了。

3.CGLIB实现代理的原理

首先创建目标对象:

public class UserManagerImpl {
    public void addUser(String userName) {
        System.out.println("UserManagerImpl add user name is:" + userName);
    }

    public void deleteUser(String userName) {
        System.out.println("UserManagerImpl delete user name is:" + userName);
    }
}

针对这个目标类,假如我们要使用动态代理实现A

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring中,如果要代理没有实现接口的类,可以使用cglib实现动态代理。下面是cglib实现动态代理的方式和例子。 首先,引入cglib的依赖: ```xml <dependency> <groupId>cglib</groupId> <artifactId>cglib</artifactId> <version>3.3.0</version> </dependency> ``` 然后,定义一个需要被代理的类RealSubject,其中不需要实现任何接口: ```java public class RealSubject { public void request() { System.out.println("RealSubject Request"); } } ``` 接下来,定义一个MethodInterceptor接口的实现类ProxyHandler,其中定义一个RealSubject类型的成员变量,用于指定代理的目标对象,然后在intercept方法中实现对目标对象方法的代理: ```java import net.sf.cglib.proxy.MethodInterceptor; import net.sf.cglib.proxy.MethodProxy; import java.lang.reflect.Method; public class ProxyHandler implements MethodInterceptor { private RealSubject realSubject; public ProxyHandler(RealSubject realSubject) { this.realSubject = realSubject; } @Override public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable { System.out.println("ProxySubject before request"); Object result = method.invoke(realSubject, args); System.out.println("ProxySubject after request"); return result; } } ``` 在ProxyHandler类中,我们在intercept方法调用目标对象的方法前后分别输出一些字符串,以此实现对目标对象的代理。 最后,我们可以在客户端代码中创建RealSubject和cglib动态代理对象,并调用request方法: ```java import net.sf.cglib.proxy.Enhancer; public class Client { public static void main(String[] args) { RealSubject realSubject = new RealSubject(); ProxyHandler proxyHandler = new ProxyHandler(realSubject); Enhancer enhancer = new Enhancer(); enhancer.setSuperclass(realSubject.getClass()); enhancer.setCallback(proxyHandler); RealSubject proxySubject = (RealSubject) enhancer.create(); proxySubject.request(); } } ``` 在客户端代码中,我们创建了一个ProxyHandler对象,并将RealSubject对象传入,然后使用Enhancer类动态生成了一个代理对象proxySubject。最后调用proxySubject的request方法,实现了对RealSubject的代理。 输出结果为: ``` ProxySubject before request RealSubject Request ProxySubject after request ``` 这就是cglib实现动态代理的方式和例子。需要注意的是,cglib动态代理的代理类是目标类的子类,因此如果目标类中有final方法,是无法代理的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值