CGLIB代理

本文介绍如何使用CGLIB实现代理模式,当目标类未实现接口时,通过CGLIB创建目标类的子类并进行方法拦截。文中详细展示了CGLIB代理工厂类的实现过程及测试方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

被代理的类如果实现接口,那么使用JDK的代理模式,设计到Proxy,InvocationHandler。
如果被代理的类没有实现接口,那么使用CGLIB来实现代理。

此类没有实现接口,要代理此类,只能使用CGLIB:

public class Operation  {

private String name;

public Operation(){}
public Operation(String name){
this.name = name;
}

public void doInsert(String name) {
System.out.println(" 操作完成 ");
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}

}



CGLIB代理的模式:


import java.lang.reflect.Method;

import net.sf.cglib.proxy.Enhancer;
import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;

public class CGLIBProxyFactory implements MethodInterceptor{

private Object delegate;

public Object createProxyInstance(Object delegate){
this.delegate = delegate;
Enhancer enhancer = new Enhancer();
enhancer.setSuperclass(this.delegate.getClass());//代理类会生产一个被代理类的子类,final方法除外
enhancer.setCallback(this);//将本身设为回调对象,必须实现接口MehtoInterceptor
return enhancer.create();
}

//代理对象被回调的时候调用此方法
public Object intercept(Object proxy, Method method, Object[] args,
MethodProxy methodProxy) throws Throwable {

Operation operation = (Operation)this.delegate;
Object result = null;
if (operation.getName()!=null) {
System.out.println("开始...");
result = methodProxy.invoke(delegate, args);
System.out.println("结束...");
}


return result;
}

}



测试方法:


public class Test {

public static void main(String[] args) {
CGLIBProxyFactory cFactory = new CGLIBProxyFactory();
Operation operation = (Operation)cFactory.createProxyInstance(new Operation("老李"));

operation.doInsert("XXX");
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值