Java | Spring框架 | AOP代理机制

大家好,我是程序员影子,一名AI+编程深耕者,点击左上角头像了解我的详细信息。

今天来聊一聊关于Java中的Spring AOP代理机制中的JDK动态代理与CGLIB。

一、JDK动态代理

JDK动态代理是Spring AOP默认使用的代理机制。它基于Java反射机制,通过实现接口的方式来创建代理对象。


代码示例:
InvocationHandler实现

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
public class MyInvocationHandler implements InvocationHandler {
    private Object target; // 目标对象
    public MyInvocationHandler(Object target) {
        this.target = target;
    }
    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        System.out.println("Before method: " + method.getName());
        Object result = method.invoke(target, args); // 调用目标对象的方法
        System.out.println("After method: " + method.getName());
        return result;
    }
}

使用JDK动态代理

import java.lang.reflect.Proxy;
public class ProxyTest {
    public static void main(String[] args) {
        // 创建目标对象
        HelloWorld helloWorld = new HelloWorldImpl();
        
        // 创建InvocationHandler对象
        InvocationHandler handler = new MyInvocationHandler(helloWorld);
        
        // 创建代理对象
        HelloWorld proxy = (HelloWorld) Proxy.newProxyInstance(
                helloWorld.getClass().getClassLoader(),
                helloWorld.getClass().getInterfaces(),
                handler);
        
        // 通过代理对象调用方法
        proxy.sayHello();
    }
}
interface HelloWorld {
    void sayHello();
}
class HelloWorldImpl implements HelloWorld {
    @Override
    public void sayHello() {
        System.out.println("Hello, World!");
    }
}

二、CGLIB代理

CGLIB是一个强大的、高性能的代码生成库。Spring AOP在创建代理对象时,如果目标对象没有实现接口,就会使用CGLIB来创建代理对象。


代码示例:
MethodInterceptor实现类

import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;
import java.lang.reflect.Method;
public class MyMethodInterceptor implements MethodInterceptor {
    @Override
    public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable {
        System.out.println("Before method: " + method.getName());
        Object result = proxy.invokeSuper(obj, args); // 调用目标对象的方法
        System.out.println("After method: " + method.getName());
        return result;
    }
}

使用CGLIB代理

import net.sf.cglib.proxy.Enhancer;
public class CglibTest {
    public static void main(String[] args) {
        // 创建Enhancer对象
        Enhancer enhancer = new Enhancer();
        
        // 设置目标类
        enhancer.setSuperclass(HelloWorldImpl.class);
        
        // 设置回调方法
        enhancer.setCallback(new MyMethodInterceptor());
        
        // 创建代理对象
        HelloWorldImpl proxy = (HelloWorldImpl) enhancer.create();
        
        // 通过代理对象调用方法
        proxy.sayHello();
    }
}
class HelloWorldImpl {
    public void sayHello() {
        System.out.println("Hello, World!");
    }
}

以上就是本次的分享,下面是影子为你带来的两份大礼。

一、欢迎加我的微信围观影子的AI编程玩法,你可以直接与影子交流,无论是Java领域还是AI编程玩法,影子都已深耕多年,期待与你的相遇~

二、加好友时备注 AI+编程,送你一份影子沉淀多个月的AI学习资料,帮助你快速入门。详细可参考下面的文章:

AI编程学习icon-default.png?t=N7T8https://blog.csdn.net/yingzix688/article/details/137894050 


最后影子再做个自我介绍:

AI+编程深耕者,致力于通过AI减少工作时间,提高开发效率,帮助小白早日踏进AIG的时代。

在影子这里,如果你是小白,你可以学习到AI+编程的入门玩法,帮助你解决一些编程开发的重复性问题;如果你有基础,影子可以给你提供进阶的知识,让你的AI+编程能力更进一步。

同时影子也会分享自己使用AI作为副业赚钱的经历。

影子的梦想是帮助更多编程小白入门AI+编程,而在即将到来的AIG时代,只会淘汰不会使用AI的编程者,希望能有更多的人可以在影子这里学习到AI编程的能力,在未来的AI时代中,不被淘汰。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值