Spring AOP 代理模式

本文介绍了Java中两种代理方式的实现:静态代理和动态代理。静态代理通过创建额外的代理类来扩展功能,而动态代理则利用反射机制在运行时动态生成代理对象。在静态代理中,我们创建了`UserdaoProxy`类作为`Userdaoimpl`的代理,实现了`add()`方法的扩展。而在动态代理中,我们创建了`Interceptor`类实现了`InvocationHandler`接口,通过`Proxy.newProxyInstance()`方法动态创建代理对象,实现了对`Userdao`接口方法的拦截和增强。

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

不改变源代码的情况下增加功能
静态代理就是定义两个实现类 一个 原有功能一个扩展功能 在扩展类里边创建委托类的对象并调用方法
实现的时候创建代理类对象并且调用

import java.text.SimpleDateFormat;
import java.util.Date;

import com.itgaoshu.dao.Userdao;
import com.itgaoshu.daoimpl.Userdaoimpl;

public class Userdaoproxy implements Userdao {
	private Userdao userdao = new Userdaoimpl();  
	public void add() {
		String date = new SimpleDateFormat("yyyy MM dd HH MM ss").format(new Date());
		System.out.println(date);
		System.out.println("proxy类add方法----add");
		userdao.add();
		System.out.println("proxy类add方法----exit");
	}
	public void remover() {
		// TODO Auto-generated method stub
	}
	public String reun(String a) {
		// TODO Auto-generated method stub
		return null;
	}
}

动态代理

接口

public interface Userdao {
	void add();
	void remover();
	String reun(String a);
}

接口实现类

public class Userdaoimpl implements Userdao {
	public void add() {
		System.err.println("实现接口 委托类-----");
		System.err.println("实现接口 -----add方法------");
	}
	public void remover() {
		System.out.println("实现类中的remover方法---------");
		
	}
	public String reun(String a) {
		return "111"+a;
	}

}

代理类

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
public class Interceptor implements InvocationHandler{
	private Object obj;
	public Object getProxy(Object obj){
		//获取当前动态代理对象
		//实现类
		//类加载器   类实现接口  当前实现类 
		System.out.println("根据实现类获取代理类对象::");
		this.obj=obj;
		return Proxy.newProxyInstance(obj.getClass().getClassLoader(), obj.getClass().getInterfaces(), this);
	}

	public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
		//生成动态代理对象 调用方法时  自动调用 invoke方法 在根据调用方法名调用实现类中的方法
		//如果不想代理某个方法可以根据调用方法名字判断
		System.out.println("动态代理----------invoke");
		System.out.println("调用方法名:"+method.getName());
		Object result = method.invoke(this.obj, args);
		System.out.println("动态代理----------invoke结束");
		return result;
	}
}
Spring AOP中的代理模式是指通过生成一个代理类,替换真实的类去对外提供服务。在Spring IOC容器中,通过使用代理类来控制对真实对象的访问。代理模式Spring AOP中主要包括静态代理、JDK动态代理和CGLib动态代理三种方式。 静态代理是指代理类在编译期就存在的方式,代理类在之前类的基础上进行了一层封装。在静态代理中,代理类持有一个被代理类的实例,在代理类中调用被代理对象的方法,并可以在方法之前或之后加入其他的方法处理逻辑。 JDK动态代理是在程序运行期动态生成代理类的方式。通过Java提供的Proxy和InvocationHandler接口,可以动态地生成代理类,实现对目标对象的代理。 CGLib动态代理也是在程序运行期动态生成代理类的方式。与JDK动态代理不同的是,CGLib动态代理通过继承的方式生成代理类,而不是实现接口。 总结来说,Spring AOP中的代理模式是通过生成代理类来控制对真实对象的访问。可以使用静态代理、JDK动态代理或CGLib动态代理的方式来实现代理模式。代理类可以在调用被代理对象的方法之前或之后加入其他的方法处理逻辑。这样可以实现一些公共的行为,如日志记录、权限验证等,避免在每个业务方法中重复编写相同的代码,提高代码的复用性和可维护性。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值