文档章节

Java动态代理

Zero零_度
 Zero零_度
发布于 2016/03/29 11:32
字数 349
阅读 21
收藏 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();
    }
    
}


© 著作权归作者所有

共有 人打赏支持
上一篇: jquery常用
下一篇: spring结合json
Zero零_度
粉丝 69
博文 1253
码字总数 256597
作品 0
程序员
私信 提问

暂无文章

区块链时代的拜占庭容错:Tendermint (七)

原文题目:《Tendermint: Byzantine Fault Tolerance in the Age of Blockchains》 原文作者:Ethan Buchman 本文为节选 软件实现 Tendermint采用Go语言实现,代码在https://github.com/tend...

万向区块链
16分钟前
5
0
日志分级输出到指定文件

log4j.properties文件 #根设置,输出级别为DEBUG级别, 输出文件为 ERRORA,stdout,DEBUGAlog4j.rootLogger=DEBUG,ERRORA,stdout,DEBUGA#过滤掉spring框架下的额外日志#log4j.category...

嘴角轻扬30
21分钟前
1
0
Hash源码分析(JDK1.7和1.8的对比)

前言 HashMap 在 Java 和 Android 开发中非常常见 而HashMap 1.8 相对于 HashMap 1.7 更新多 今天,我将通过源码分析HashMap 1.8 ,从而讲解HashMap 1.8 相对于 HashMap 1.7 的更新内容,希望...

瑞查德-Jack
21分钟前
3
0
Amino——表现层

一、Amino 整体视觉感受 Amino采用的主题色是神秘的蓝紫色,搭配白色图标和文字,其他图标、按钮、卡片等采用饱和度较高的亮色,整体风格活泼灵动。蓝紫色给人一种神秘感,好比陌生人之间的社...

铸剑为犁413
23分钟前
1
0
日志服务与SIEM(如Splunk)集成方案实战

背景信息 目标 本文主要介绍如何让阿里云日志服务与您的SIEM方案(如Splunk)对接, 以便确保阿里云上的所有法规、审计、与其他相关日志能够导入到您的安全运维中心(SOC)中。 名词解释 LOG(S...

阿里云官方博客
34分钟前
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部