文档章节

Java动态代理

Zero零_度
 Zero零_度
发布于 2016/03/29 11:32
字数 349
阅读 21
收藏 0
点赞 1
评论 0

Java动态代理

package com.server;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;

//InvocationHandler是一个监听器, 当代理对象调用任何方法的时候都会经过InvocationHandler的invoke方法
public class ProxyHelper implements InvocationHandler {

    private TimerService target;
    
    public void setTarget(TimerService target) {
        this.target = target;
    }
    
    @Override
    // proxy 是拦截到的代理对象    args是方法参数
    public Object invoke(Object proxy, Method method, Object[] args)
            throws Throwable {
        System.out.println("执行" + method.getName() + "方法前,记录日志。。。");
        method.invoke(target, args);
        System.out.println("执行" + method.getName() + "方法后,记录日志。。。");
        return null;
    }
}

写法二:

package com.server;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

// InvocationHandler是一个监听器, 当代理对象调用任何方法的时候都会经过InvocationHandler的invoke方法
public class ProxyHelper implements InvocationHandler {
    
    private Object target;   // 先备份目标
    
    public Object newProxyInstance(Object target){
        this.target = target;  // *****
        return Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), this);
    }
    
    // proxy.a();
    public Object invoke(Object arg0, Method arg1, Object[] arg2)
            throws Throwable {
        System.out.println("代理对象调用方法了....调用的是"+arg1.getName());
        System.out.println(arg1.getName()+"开始执行, 开始记录日志");
        // target.a(参数);
        // arg0 是拦截到的代理对象
        try{
        arg1.invoke(target, arg2);
        }catch(Exception e){
            System.out.println(arg1.getName()+"出现异常, 开始记录日志");
        }
        System.out.println(arg1.getName()+"执行完毕");
        return null;
    }
    
    
    // 之前切面: 打开session  启动事务
    // dao 功能执行                   --------------------> 异常切面
    // 之后切面: 提交事务 关闭session

}

调用:

package com.server;

import java.lang.reflect.Proxy;

public class Client {
    
    public static void main(String[] args) {
        TimerService target = new TimerBean();        // 这里可以利用Spring的注入
        ProxyHelper helper = new ProxyHelper();
        helper.setTarget(target);
        TimerService service = (TimerService)Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), helper);
        service.b();
    }
    
}


© 著作权归作者所有

共有 人打赏支持
Zero零_度
粉丝 67
博文 1245
码字总数 252866
作品 0
程序员

暂无文章

10.28 rsync工具介绍 , rsync常用选项, rsync通过ssh同步

rsync远程同步 重点!重点!!重点!!! 例子 • rsync -av /etc/passwd /tmp/1.txt • rsync -av /tmp/1.txt 192.168.188.128:/tmp/2.txt rsync格式 • rsync [OPTION] … SRC DEST • rs......

Linux_老吴
7分钟前
0
0
iis php 环境搭建,非常详细的教程

准备篇 一、环境说明: 操作系统:Windows Server 2016 PHP版本:php 7.1.0 MySQL版本:MySQL 5.7.17.0 二、相关软件下载: 1、PHP下载地址: http://windows.php.net/downloads/releases/ph...

T_star
10分钟前
0
0
Day35 rsync通过服务同步

rsync通过服务同步 rsyncd.conf配置文件详解 port:指定在哪个端口启动rsyncd服务,默认是873端口。 log file:指定日志文件。 pid file:指定pid文件,这个文件的作用涉及服务的启动、停止等...

杉下
15分钟前
0
0
【最新最全】为 iOS 和 Android 的真机和模拟器编译 Luajit 库

编译 Luajit 库,的确是一个挑战。因为官网的教程,在当前版本的 Xcode 和 NDK 环境中,已经不适用了。以前只是编译了适用于真机的 Luajit 库。最近在尝试编译模拟器 Luajit 库,就顺便梳理了...

ios122
15分钟前
0
0
rsync至ssh同步

rsync: 文件同步工具,可实现“增量拷贝”;使用yum安装rsync包 常用选项:-a=-rtplgoD (-r同步目录,-t保持文件的时间属性,-p保持文件的权限属性,-l保持软连接,-g保持文件的属组,-o保持...

ZHENG-JY
21分钟前
0
0
TradingView 学习笔记

#前言 公司最后需要使用TradingView展示K线图走势。由于之前没接触过,拿到文档时一脸蒙逼。还好找到二篇文章+Demo代码,直接改改就行了。 #被批 由于上面的懵懂,有个问题困扰4个小时没解决...

hihubs
21分钟前
0
0
10.28 rsync工具介绍~10.31 rsync通过ssh同步

rsync命令是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件。rsync使用所谓的“rsync算法”来使本地和远程两个主机之间的文件达到同步,这个算法只传送两个文件的不同部分,而...

洗香香
23分钟前
1
0
php如何使用JSON-RPC查找以太坊中的最新块哈希hash值?

我用PHP中开发了一个以太坊块资源管理器,并成功地与我的服务器Geth节点建立了JSON-RPC通信。然而,当我试图找出最后一个区块时,我陷入了困境。我在https://ethereum.gitbooks.io/frontier...

智能合约
29分钟前
1
0
卷积为什么要旋转180度

参考《最容易理解的对卷积(convolution)的解释》 https://blog.csdn.net/bitcarmanlee/article/details/54729807 这篇博客详细讲解了“卷积”,提及了为什么要反转180度,我简述下。 1.卷积的...

datadev_sh
32分钟前
0
0
【2018.07.18学习笔记】【linux高级知识 20.23-20.26】

20.23/20.24/20.25 告警系统邮件引擎 20.26 运行告警系统

lgsxp
37分钟前
16
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部