Java代理模式(cglib代理)

java提供的基於Proxy、InvocationHandler的動態代理由於只能創建接口的代理對象,在實際應用中不能很好的滿足需要,針對這個問題,另外一個開源框架cglib提供了一種實現方式,可以針對類進行代理對象的創建。

CGLib採用了非常底層的字節碼技術,其原理是通過字節碼技術爲一個類創建子類,並在子類中採用方法攔截的技術攔截所有父類方法的調用,順勢織入橫切邏輯。JDK動態代理與CGLib動態代理均是實現Spring AOP的基礎。

其中Hibernate懶加載使用的代理方式就是Cglib動態代理

實例如下:

1、原始對象:

public class Operate {

	public void delete(){
		System.out.println("刪除操作");
	}
}


2、代理實現:

public class CglibProxy implements MethodInterceptor{

	private Enhancer enhancer = new Enhancer();
	/**
	 * 生成代理子類
	 * @param clazz
	 * @return
	 */
	@SuppressWarnings("rawtypes")
	public Object getProxy(Class clazz){
		enhancer.setSuperclass(clazz);
		enhancer.setCallback(this);
		return enhancer.create();
	}
	
	/**
	 * 攔截方法
	 * object 代理對象實例  
	 * method 原始對象的方法名  
	 * arg2 傳遞給方法的實際入參  
	 * proxy 與源對象中的method相對應的代理對象中的方法 
	 */
	@Override
	public Object intercept(Object object, Method method, Object[] arg2, MethodProxy proxy) throws Throwable {
		// TODO Auto-generated method stub
		System.out.println("前置操作");
		Object result = proxy.invokeSuper(object, arg2);
		System.out.println("後置操作");
		return result;
	}

}



3、客戶端實現:

public class Client {

	public static void main(String []args){
		CglibProxy cglibProxy = new CglibProxy();
		Operate operate = (Operate)cglibProxy.getProxy(Operate.class);
		operate.delete();
	}
}

運行結果:

前置操作
刪除操作
後置操作

以上可以看出cglib代理可以實現沒有接口類的proxy代理

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章