亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

java使用動態代理來實現AOP(日志記錄)的實例代碼

2019-11-26 15:57:38
字體:
來源:轉載
供稿:網友

下面是一個AOP實現的簡單例子:

首先定義一些業務方法:

復制代碼 代碼如下:

/**
 * Created with IntelliJ IDEA.
 * Author: wangjie  email:tiantian.china.2@gmail.com
 * Date: 13-9-23
 * Time: 下午3:49
 */
public interface BussinessService {
    public String login(String username, String password);
    public String find();
}

public class BussinessServiceImpl implements BussinessService {
    private Logger logger = Logger.getLogger(this.getClass().getSimpleName());

    @Override
    public String login(String username, String password) {
        return "login success";
    }

    @Override
    public String find() {
        return "find success";
    }

}


復制代碼 代碼如下:

/**
 * Created with IntelliJ IDEA.
 * Author: wangjie  email:tiantian.china.2@gmail.com
 * Date: 13-9-24
 * Time: 上午10:27
 */
public interface WorkService {
    public String work();
    public String sleep();
}

public class WorkServiceImpl implements WorkService{
    @Override
    public String work() {
        return "work success";
    }

    @Override
    public String sleep() {
        return "sleep success";
    }
}


實現InvocationHandler接口,使用map來存儲不同的InvocationHandler對象,避免生成過多。

復制代碼 代碼如下:

package com.wangjie.aoptest2.invohandler;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.Arrays;
import java.util.HashMap;
import java.util.logging.Logger;

/**
 * Created with IntelliJ IDEA.
 * Author: wangjie  email:tiantian.china.2@gmail.com
 * Date: 13-9-23
 * Time: 下午3:47
 */
public class LogInvoHandler implements InvocationHandler{
    private Logger logger = Logger.getLogger(this.getClass().getSimpleName());

    private Object target; // 代理目標
    private Object proxy; // 代理對象

    private static HashMap<Class<?>, LogInvoHandler> invoHandlers = new HashMap<Class<?>, LogInvoHandler>();

    private LogInvoHandler() {
    }

    /**
     * 通過Class來生成動態代理對象Proxy
     * @param clazz
     * @return
     */
    public synchronized static<T> T getProxyInstance(Class<T> clazz){
        LogInvoHandler invoHandler = invoHandlers.get(clazz);

        if(null == invoHandler){
            invoHandler = new LogInvoHandler();
            try {
                T tar = clazz.newInstance();
                invoHandler.setTarget(tar);
                invoHandler.setProxy(Proxy.newProxyInstance(tar.getClass().getClassLoader(),
                        tar.getClass().getInterfaces(), invoHandler));
            } catch (Exception e) {
                e.printStackTrace();
            }
            invoHandlers.put(clazz, invoHandler);

        }

        return (T)invoHandler.getProxy();
    }

    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {

        Object result = method.invoke(target, args); // 執行業務處理

        // 打印日志
        logger.info("____invoke method: " + method.getName()
                    + "; args: " + (null == args ? "null" : Arrays.asList(args).toString())
                    + "; return: " + result);


        return result;
    }

    public Object getTarget() {
        return target;
    }

    public void setTarget(Object target) {
        this.target = target;
    }

    public Object getProxy() {
        return proxy;
    }

    public void setProxy(Object proxy) {
        this.proxy = proxy;
    }
}


然后編寫一個Test類測試:

復制代碼 代碼如下:

/**
 * Created with IntelliJ IDEA.
 * Author: wangjie  email:tiantian.china.2@gmail.com
 * Date: 13-9-24
 * Time: 上午9:54
 */
public class Test {
    public static Logger logger = Logger.getLogger(Test.class.getSimpleName());
    public static void main(String[] args) {

        BussinessService bs = LogInvoHandler.getProxyInstance(BussinessServiceImpl.class);
        bs.login("zhangsan", "123456");
        bs.find();

        logger.info("--------------------------------------");

        WorkService ws = LogInvoHandler.getProxyInstance(WorkServiceImpl.class);
        ws.work();
        ws.sleep();

        logger.info("--------------------------------------");

        BussinessService bss = LogInvoHandler.getProxyInstance(BussinessServiceImpl.class);
        bss.login("lisi", "654321");
        bss.find();

    }
}


以后需要添加新的業務邏輯XXXService,只需要調用

XXXService xs = LogInvoHandler.getProxyInstance(XXXServiceImpl.class);

即可。

也可以模仿Spring等框架的配置,把bean的類名配置在xml文件中,如:

<bean id="bussinessService" class="com.wangjie.aoptest2.service.impl.BussinessServiceImpl">

然后在java代碼中解析xml,通過Class.forName("com.wangjie.aoptest2.service.impl.BussinessServiceImpl");獲得Class對象

然后通過LogInvoHandler.getProxyInstance(Class.forName("com.wangjie.aoptest2.service.impl.BussinessServiceImpl"));獲得代理對象Proxy

再使用反射去調用代理對象的方法。

 

運行結果如下:

九月 24, 2013 11:08:03 上午 com.wangjie.aoptest2.invohandler.LogInvoHandler invoke
INFO: ____invoke method: login; args: [zhangsan, 123456]; return: login success
九月 24, 2013 11:08:03 上午 com.wangjie.aoptest2.invohandler.LogInvoHandler invoke
INFO: ____invoke method: find; args: null; return: find success
九月 24, 2013 11:08:03 上午 com.wangjie.aoptest2.Test main
INFO: --------------------------------------
九月 24, 2013 11:08:03 上午 com.wangjie.aoptest2.invohandler.LogInvoHandler invoke
INFO: ____invoke method: work; args: null; return: work success
九月 24, 2013 11:08:03 上午 com.wangjie.aoptest2.invohandler.LogInvoHandler invoke
INFO: ____invoke method: sleep; args: null; return: sleep success
九月 24, 2013 11:08:03 上午 com.wangjie.aoptest2.Test main
INFO: --------------------------------------
九月 24, 2013 11:08:03 上午 com.wangjie.aoptest2.invohandler.LogInvoHandler invoke
INFO: ____invoke method: login; args: [lisi, 654321]; return: login success
九月 24, 2013 11:08:03 上午 com.wangjie.aoptest2.invohandler.LogInvoHandler invoke
INFO: ____invoke method: find; args: null; return: find success

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美中文字幕在线观看| 国产精品成人一区二区三区吃奶| 欧美日韩一区二区在线播放| 亚洲成人精品av| 国产成人97精品免费看片| 播播国产欧美激情| 日韩av网址在线| 中文字幕精品一区二区精品| 亚洲亚裔videos黑人hd| 国产精自产拍久久久久久蜜| 久久久精品2019中文字幕神马| 日韩在线视频一区| 久久久中精品2020中文| 亚洲视频在线免费看| 精品国产拍在线观看| 欧美日韩ab片| 7777kkkk成人观看| 97免费在线视频| 97精品在线视频| 日韩美女视频中文字幕| 国产精品老女人精品视频| 欧美精品在线极品| 国产精品自产拍在线观看中文| 亚洲欧美www| 色先锋资源久久综合5566| 亚洲电影免费观看高清完整版在线观看| 欧美激情视频播放| 色综合色综合网色综合| 日韩美女在线观看| 中文字幕在线看视频国产欧美在线看完整| 97在线视频免费播放| 91久久久亚洲精品| 992tv成人免费影院| 国产婷婷成人久久av免费高清| 精品视频www| 视频在线观看一区二区| 国产精品久久久久久影视| 国产精品美女主播| 成人午夜高潮视频| 日产精品久久久一区二区福利| 精品久久中文字幕久久av| 夜色77av精品影院| 久久久久久999| 日韩精品久久久久| 国产免费观看久久黄| 欧美日韩国内自拍| 精品国偷自产在线| 国产一区二区美女视频| 国产精品久久久久久久久久东京| 国产在线观看精品一区二区三区| 理论片在线不卡免费观看| 国产欧美精品在线| 91精品久久久久久久久中文字幕| 亚洲精品中文字幕有码专区| 欧美精品18videosex性欧美| 国产一区二区黑人欧美xxxx| 97在线看免费观看视频在线观看| 亚洲成成品网站| 国产综合久久久久久| 国产成人短视频| 成人久久一区二区三区| 日本久久亚洲电影| 欧美激情亚洲另类| 久热精品视频在线免费观看| 欧美大肥婆大肥bbbbb| 亚洲电影免费观看| 亚洲在线视频福利| 亚洲图片在区色| 国产一区二区在线免费视频| 色综合天天狠天天透天天伊人| 2025国产精品视频| 亚洲色在线视频| 亚洲精品综合久久中文字幕| 欧美一级电影免费在线观看| 欧美专区在线播放| www.欧美免费| 中文字幕日韩精品有码视频| 亚洲人成伊人成综合网久久久| 欧美日韩一区二区在线| 国产精品jvid在线观看蜜臀| 国产精品中文字幕久久久| 国产精品视频导航| 欧美性20hd另类| 欧美亚洲一区在线| 成人激情视频免费在线| 91亚洲永久免费精品| 丝袜美腿精品国产二区| 成人国产精品一区| 日韩精品中文字幕有码专区| 日韩中文字幕国产精品| 欧美巨猛xxxx猛交黑人97人| 欧美与黑人午夜性猛交久久久| 亚洲影院高清在线| 精品动漫一区二区| 欧美性猛交xxxx富婆弯腰| 国产日韩精品电影| 欧美激情视频在线免费观看 欧美视频免费一| 成人国产精品久久久久久亚洲| 久久精品国产一区二区三区| 奇米一区二区三区四区久久| 国产婷婷色综合av蜜臀av| 日本精品免费观看| 久久影视电视剧免费网站清宫辞电视| 欧美在线视频网| 久久久久久久久久亚洲| 久久理论片午夜琪琪电影网| 国产欧美日韩精品在线观看| 亚洲精品videossex少妇| 国产偷亚洲偷欧美偷精品| 少妇高潮久久久久久潘金莲| 91精品视频观看| 久久综合久中文字幕青草| 亚洲视频一区二区三区| 伊人青青综合网站| 中文字幕一区电影| 性金发美女69hd大尺寸| 精品久久香蕉国产线看观看gif| 欧美性感美女h网站在线观看免费| 亚洲成人黄色在线| www.国产精品一二区| 欧美日韩国产色| 国产一区视频在线| 日韩精品亚洲视频| 欧美激情视频三区| 国产欧美一区二区白浆黑人| 久久韩国免费视频| 91影视免费在线观看| 亚洲天堂av在线免费| 中文字幕亚洲欧美日韩在线不卡| 亚洲成人动漫在线播放| 人人爽久久涩噜噜噜网站| 久久久久久久久久久av| 欧美巨乳美女视频| 国产一区二区三区视频| 亚洲va码欧洲m码| 2019日本中文字幕| 欧美wwwxxxx| 亚洲精品丝袜日韩| 欧美二区在线播放| 日本欧美一二三区| 国产精品久久久久一区二区| 国产亚洲视频在线| 成人久久一区二区| 一本一道久久a久久精品逆3p| 欧美国产第二页| 久久久成人av| 色yeye香蕉凹凸一区二区av| 色综合亚洲精品激情狠狠| 国产精品入口尤物| 国内精品中文字幕| 一本大道亚洲视频| 热99精品里视频精品| 久久青草精品视频免费观看| 欧美尤物巨大精品爽| 国产亚洲一级高清| 日本高清久久天堂| 欧美一级高清免费播放| 欧美性生活大片免费观看网址| 7777kkkk成人观看| 亚洲香蕉av在线一区二区三区| 九九热精品视频在线播放| 欧美小视频在线观看| 中文亚洲视频在线| 欧日韩在线观看|