JDK动态代理和cglib动态代理

动态代理是一种在运行时创建代理对象的机制,它可以在不修改源代码的情况下,对方法进行增强或拦截。在Java中,有两种常见的实现动态代理的方式:JDK动态代理和CGLIB动态代理。

JDK动态代理

JDK动态代理是Java提供的一种基于接口的代理方式。它要求被代理的类必须实现一个接口,并且通过Java原生的java.lang.reflect.Proxy类和java.lang.reflect.InvocationHandler接口来创建代理对象。

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

public interface HelloService {
    void sayHello();
}

public class HelloServiceImpl implements HelloService {
  	@Override
    public void sayHello() {
        System.out.println("Hello!");
    }
}

public class HelloServiceProxy implements InvocationHandler {
    private Object target;
	
    public Object bind(Object target) {
        this.target = target;
        return Proxy.newProxyInstance(target.getClass().getClassLoader(),
                target.getClass().getInterfaces(), this);
    }
  @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        // 在方法执行前进行增强
        System.out.println("Before invoking sayHello()");
        Object result = method.invoke(target, args);
        // 在方法执行后进行增强
        System.out.println("After invoking sayHello()");
        return result;
    }
}

public class Main {
    public static void main(String[] args) {
        HelloService helloService = new HelloServiceImpl();
        HelloServiceProxy proxy = new HelloServiceProxy();
        HelloService helloServiceProxy = (HelloService) proxy.bind(helloService);
        helloServiceProxy.sayHello();
    }
}

Before invoking sayHello()
Hello!
After invoking sayHello()

CGLIB动态代理

CGLIB动态代理是基于继承的代理方式,它通过创建目标类的子类来实现代理。相比JDK动态代理,CGLIB动态代理不要求被代理的类实现接口,但需要依赖第三方库CGLIB。

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

public class HelloService {
    public void sayHello() {
        System.out.println("Hello!");
    }
}

public class HelloServiceInterceptor implements MethodInterceptor {
 	@Override
    public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable {
        // 在方法执行前进行增强
        System.out.println("Before invoking sayHello()");
        Object result = proxy.invokeSuper(obj, args);
        // 在方法执行后进行增强
        System.out.println("After invoking sayHello()");
        return result;
    }
}

public class Main {
    public static void main(String[] args) {
        Enhancer enhancer = new Enhancer();
        enhancer.setSuperclass(HelloService.class);
        enhancer.setCallback(new HelloServiceInterceptor());
        HelloService helloService = (HelloService) enhancer.create();
        helloService.sayHello();
    }
}

Before invoking sayHello()
Hello!
After invoking sayHello()

spring中使用jdk动态代理

public interface HelloService {
    void sayHello();
}

public class HelloServiceImpl implements HelloService {
    @Override
    public void sayHello() {
        System.out.println("Hello!");
    }
}

创建bean

@Configuration
public class AppConfig {
    @Bean
    public HelloService helloService() {
        return new HelloServiceImpl();
    }
}

注入:

@Service
public class HelloServiceConsumer {
    @Autowired
    private HelloService helloService;

    public void invokeHelloService() {
        helloService.sayHello();
    }
}

基于cglib

public class HelloService {
    public void sayHello() {
        System.out.println("Hello!");
    }
}

@Configuration
@EnableAspectJAutoProxy(proxyTargetClass = true)
public class AppConfig {
    @Bean
    public HelloService helloService() {
        return new HelloService();
    }
}

使用:

@Service
public class HelloServiceConsumer {
    @Autowired
    private HelloService helloService;

    public void invokeHelloService() {
        helloService.sayHello();
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

源城编程哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值