中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java如何通過動態代理實現一個簡單的攔截器操作

發布時間:2021-07-09 13:37:37 來源:億速云 閱讀:124 作者:chen 欄目:開發技術

這篇文章主要介紹“Java如何通過動態代理實現一個簡單的攔截器操作”,在日常操作中,相信很多人在Java如何通過動態代理實現一個簡單的攔截器操作問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Java如何通過動態代理實現一個簡單的攔截器操作”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

一、代理

在使用動態代理實現攔截器之前我們先簡單了解一下什么Java的代理。

代理,顧名思義,就是不直接操作被代理(下面都用目標對象稱呼,聽起來舒服一些)對象,而是通過一個代理對象去間接的使用目標對象中的方法。代理分為兩種模式,一種是靜態代理,一種是動態代理。接下來先寫一個靜態代理的例子。

無論是靜態代理還是動態代理,目標對象(target)都要實現一個接口(interface),注意,如果使用cglib提供的代理,則不必實現接口,而是通過子類去實現,暫不討論該種方式。

(1)先定義一個接口

public interface IUserDao {
    void save();
}

(2)定義目標對象(target)

public class UserDaoImpl implements IUserDao {
    public void save() {
        System.out.println("--------已經保存數據---------");
    }
}

(3)定義代理對象

public class UserDaoProxy implements IUserDao {
 private IUserDao target;//將目標對象放到代理對象中
 public UserDaoProxy(IUserDao target){
  this.target = target;
  }
 public void save() {
     System.out.println("------開始事務------");
            target.save();
     System.out.println("-------提交事務------");
    }
}

測試一下:

public class Test {
public static void main(String[] args){
    IUserDao userDao = new UserDaoImpl();
    UserDaoProxy proxy = new UserDaoProxy(userDao);
    proxy.save();//通過代理對象調用save方法
    }
}

輸出結果為:

------開始事務------
--------已經保存數據---------

-------提交事務------

這種方式有一個問題,就是代理對象必須也要實現被代理對象所實現的同一個接口,這就出現了嚴重的耦合。所以,下面使用一種改進的方式,即動態代理(jdk代理)。

動態代理方式也需要目標對象(target)實現一個接口

(1)定義一個接口(IUserDao)

(2)定義一個目標對象類(UserDaoImpl)

(3)創建動態代理類

public class ProxyFactory {
    //維護一個目標對象
    private Object target; 
    public ProxyFactory(Object target) {
        this.target = target;
    }
 
    //給目標對象生成代理對象
    public Object getProxyInstance() {
        System.out.println("----target class---" + target.getClass());
        System.out.println("----target interfaces---" +
            target.getClass().getInterfaces());
 
        return Proxy.newProxyInstance(target.getClass().getClassLoader(),
            target.getClass().getInterfaces(),
            new InvocationHandler() {
                public Object invoke(Object proxy, Method method, Object[] args)
                    throws Throwable {
                    System.out.println("----開始事務2-----");
 
                    //執行目標對象方法
                    Object returnValue = method.invoke(target, args);
                    System.out.println("----提交事務2----");
 
                    return returnValue;
                }
            });
    }
}

測試一下:

public class Test {
    public static void main(String[] args) {
        //目標對象
        IUserDao target = new UserDao();
        System.out.println(target.getClass());
 
        //給目標對象創建代理對象
        IUserDao proxy = (IUserDao) new ProxyFactory(target).getProxyInstance();
        System.out.println("----proxy----:" + proxy.getClass());
        proxy.save();
        proxy.delete();
    }
}

輸出結果:

class com.jd.pattern.proxy.dynamicProxy.UserDao
----target class---class com.jd.pattern.proxy.dynamicProxy.UserDao
----target interfaces---[Ljava.lang.Class;@1fb3ebeb
----proxy----:class com.sun.proxy.$Proxy0
----開始事務2-----
-----保存完成------
----提交事務2----
----開始事務2-----
----刪除完成----

----提交事務2----

二、使用動態代理實現一個簡單的攔截器

既然是采用動態代理的方式,那么肯定會有 接口、目標類、代理類,再加一個攔截器

1、定義一個接口

public interface BusinessFacade {
    void doSomething();
}

2、定義一個目標對象

public class BusinessClass implements BusinessFacade {
    public void doSomething() {
        System.out.println("在業務組件BusinessClass中調用doSomething方法");
    }
}

3、創建攔截器

public class InterceptorClass {
    public void before() {
        System.out.println("在InterceptorClass中調用方法:before()");
    }
 
    public void after() {
        System.out.println("在InterceptorClass中調用方法:after()");
    }
}

4、創建代理

public class DynamicProxyHandler {
    //聲明被代理對象
    private Object target;
    //創建攔截器
    InterceptorClass interceptor = new InterceptorClass();
    //動態生成一個代理對象,并綁定被代理類和代理處理器
    public Object getProxyInstance(final Object target) {
        this.target = target;
        return Proxy.newProxyInstance(target.getClass().getClassLoader(),
            target.getClass().getInterfaces(),
            new InvocationHandler() {
                public Object invoke(Object proxy, Method method, Object[] args)
                    throws Throwable {
                    interceptor.before();
                    Object result = method.invoke(target, args);
                    interceptor.after();
                    return result;
                }
            });
    }
}

測試一下:

public class Test {
    public static void main(String[] args) {
        //創建動態代理工具
        DynamicProxyHandler proxyHandler = new DynamicProxyHandler();
        //創建業務組件
        BusinessFacade target = new BusinessClass();
        //獲取代理對象
        BusinessFacade proxy = (BusinessFacade) proxyHandler.getProxyInstance(target);
        //通過代理對象調用目標對象方法
        proxy.doSomething();
    }
}

輸出結果:

在InterceptorClass中調用方法:before()
在業務組件BusinessClass中調用doSomething方法
在InterceptorClass中調用方法:after()

到此,關于“Java如何通過動態代理實現一個簡單的攔截器操作”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

谢通门县| 香港| 梓潼县| 江安县| 修文县| 奉节县| 广宁县| 安丘市| 玛纳斯县| 绩溪县| 克拉玛依市| 鲁甸县| 崇阳县| 安龙县| 晋宁县| 姜堰市| 招远市| 大方县| 石门县| 凤山县| 合阳县| 腾冲县| 红安县| 宁国市| 山西省| 丰原市| 个旧市| 电白县| 饶阳县| 外汇| 邛崃市| 邹城市| 哈巴河县| 彭山县| 塘沽区| 阳新县| 宁晋县| 宁国市| 广水市| 应城市| 拉萨市|