`
dwj147258
  • 浏览: 195743 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

JAVA代理

阅读更多

在java开发中,有很多地方都会用到代理,代理也有很多的方式可以实现,这里先介绍java自带的实现接口InvocationHandler方式:

首先来举一个例子,有这么一个类:BookFacadeProxy  

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
  
/** 
 * JDK动态代理代理类 
 *  
 * @author student 
 * 
 *  
 */ 

public class BookFacadeProxy implements InvocationHandler {  
    private Object target;  
    /** 
     * 绑定委托对象并返回一个代理类 
     * @param target 
     * @return 
     */  
    public Object bind(Object target) {  
        this.target = target;  
        //取得代理对象  
        return Proxy.newProxyInstance(target.getClass().getClassLoader(),  
                target.getClass().getInterfaces(), this);   //要绑定接口(这是一个缺陷,cglib弥补了这一缺陷)  
    }  
  
    @Override  
    /** 
     * 调用方法 
     */  
    public Object invoke(Object proxy, Method method, Object[] args)  
            throws Throwable {  
        Object result=null;  
        System.out.println("事物开始");  
        //执行方法  
        result=method.invoke(target, args);  
        System.out.println("事物结束");  
        return result;  
    }  
  
}

又有这么一个实例类:

public class BookFacadeImpl implements BookFacade {  
  
    @Override  
    public void addBook() {  
        System.out.println("增加图书方法。。。");  
    }  
    public void removeBook(){
    	System.out.println("移除图书方法...");
    }
}

  

 

这就是代理的一个简单实现,测试一下:

public static void main(String[] args) {  
        BookFacadeProxy proxy = new BookFacadeProxy();  
        BookFacade bookProxy = (BookFacade) proxy.bind(new BookFacadeImpl());  
        bookProxy.addBook();  
        bookProxy.removeBook();
        
        /*CGlibProxy proxy = new CGlibProxy();  
        Train t = (Train) proxy.getProxy(Train.class);  
        t.move(); 
        t.stop();*/
    }

 输出:

事物开始

增加图书方法。。。

事物结束

事物开始

移除图书方法...

事物结束

 

这就是代理的简单实现,在实际开发中,当我们想调用别人的方法之后或者之前加一些自己的东西,那么就可以通过代理来实现,下面介绍一个完整实例:

 

首先写一个实现InvocationHandler接口的类,

public abstract class MyInterfaceProxyHandler<T> implements InvocationHandler{
	protected T t;   
    
	public void setT(T t){   
		this.t = t;   
	}  
	
	@Override
	public Object invoke(Object proxy, Method method, Object[] args)
			throws Throwable {
		Object result = beforeCalled(proxy, method, args);
		if(result == null){
			result = method.invoke(t, args);
		}
		
		afterCalled(result);
		
		return result;
	}
	
	protected abstract Object beforeCalled(Object proxy, Method method, Object[] args);
	
	protected abstract void afterCalled(Object result);

	@SuppressWarnings({ "hiding", "unchecked" })
	protected <T> T createProxy(){
		return (T) Proxy.newProxyInstance(t.getClass().getClassLoader(), t.getClass().getInterfaces(), this);
	}
}

 然后写一个实现类:

package com.shjv.scs.proxy;

import java.lang.reflect.Method;
import java.util.HashMap;
import java.util.Map;

import com.shjv.scs.cm.dao.dev.DevBasicInfoDAO;
import com.shjv.scs.cm.service.dev.DevService;
import com.shjv.scs.dev.DevType;
import com.shjv.scs.domain.dev.DevConmmonInfo;
import com.shjv.scs.mediation.enumdef.MediationEnum.IecTeleControlActionType;
import com.shjv.scs.mediation.enumdef.MediationEnum.IecTeleControlType;
import com.shjv.scs.plsc.msg.PlscSignalValueUtil;
import com.shjv.scs.plsc.protocol.plsc.executor.IecPlscTeleControl;
import com.shjv.tdscdma.omc.common.lm.OMCLog;
import com.shjv.tdscdma.omc.common.lm.OMCLogFactory;
import com.shjv.tdscdma.omc.server.adapter.protocol.iec.iec104.constant.IecConstant.TeleControlType;

public class DevServiceProxy extends MyInterfaceProxyHandler<DevService> {
	private OMCLog log = OMCLogFactory.getOMCLog(DevServiceProxy.class);
	private DevBasicInfoDAO devBasicInfoDAO;
	
	@Override
	protected Object beforeCalled(Object proxy, Method method, Object[] args) {
		Object result = null;
		try {
			if ("operateDev".equals(method.getName())) {
				}
	}


	@Override
	protected void afterCalled(Object result) {
		
	}

	public void setDevBasicInfoDAO(DevBasicInfoDAO devBasicInfoDAO) {
		this.devBasicInfoDAO = devBasicInfoDAO;
	}

	@Override
	public void setT(DevService t) {
		super.setT(t);
	}

	@SuppressWarnings("unchecked")
	@Override
	public DevService createProxy() {
		return super.createProxy();
	}
	
}

 然后在spring配置文件中注入属性

<bean id="devServiceFactory" class="com.shjv.scs.proxy.DevServiceProxy">

   <property name="t" ref="devService"/>

        <property name="devBasicInfoDAO" ref="devBasicInfoDAO"/>

 

    </bean>

并通过工厂方法来获取

<bean id="devServiceProxy" factory-bean="devServiceFactory" factory-method="createProxy">

   </bean>

这样就可以实现代理,可以代理属性中的一切方法,当然以前获取属性的地方需要改成获取devServiceProxy,这样才能完成代理

 

 

 

 

 

分享到:
评论

相关推荐

    lotus domino java代理_获取传递值json

    Lotus Domino Java 代理获取传递值 JSON Lotus Domino 是一种基于Notes技术的服务器端应用程序, Lotus Domino Java 代理是指在 Domino 服务器上运行的 Java 代理程序,可以用来处理用户请求、提供数据服务等。今天...

    lotus domnio java代理输出html代理

    Lotus Domino是一个企业级的应用开发平台,而Java代理在Lotus Domino中被用来处理服务器端的任务,例如数据处理、业务逻辑或响应HTTP请求。在这个特定的案例中,`JQueryReportToolJavaAgent`是一个Java代理,它被...

    lotus domnio java代理传值

    在Lotus Domino开发环境中,Java代理是用于执行服务器端任务的重要工具,它们可以自动化许多功能,如处理数据、发送邮件等。"lotus domnio java代理传值"这个主题主要涉及如何在Java代码中创建和使用代理,并在代理...

    Java代理模式Java动态代理

    ### Java代理模式与Java动态代理详解 #### 一、代理模式概述 代理模式是一种软件设计模式,它在客户端和目标对象之间提供了一种间接层。这种模式的主要目的是控制客户端对目标对象的访问,并且可以在不修改原有...

    java代理实现webservice接口拦截器功能

    本文根据java代理实现CXF拦截器异常时只能进入fault拦截器而不能继续向下执行的问题。 利用java代理让RMI具有拦截器的功能。

    lotus Domino BS开发 通过java 代理导出excel.doc

    本教程将聚焦于如何利用Java代理来实现Excel文档的导出。 Lotus Domino是一款强大的协作软件,它提供了丰富的开发环境,包括服务器端的LotusScript和客户端的JavaScript,但在此场景下,我们使用的是Java代理,因为...

    lotus domnio java代理获取当前用户名

    在 Lotus Domino 中,Java 代理是可以运行在 Domino 服务器上的小程序,它可以执行特定的任务,如获取当前用户名。 在 Java 代理中,获取当前用户名是一个常见的需求。 Lotus Domino 提供了多种方式来获取当前...

    java代理模式

    Java代理模式是一种设计模式,它在面向对象编程中扮演着重要的角色,主要目的是为了在不修改原有对象的基础上,为对象添加额外的功能或者控制对对象的访问。代理模式的核心思想是通过代理类来间接调用目标类的方法,...

    Java代理模式例子

    Java代理模式 事例很生动,非常容易理解,推荐给大家。

    java 代理服务器源码

    java 代理服务源码 测试通过可以,可以自己修改成为自己的代理类。

    Java代理服务器程序

    Java代理服务器程序是一种用于转发网络请求的应用,它在客户端与目标服务器之间起到中介的作用。这样的设计使得用户可以通过代理服务器访问互联网,从而实现多种功能,如匿名浏览、负载均衡、缓存优化、网络监控等。...

    java代理机制 JDK动态代理和cglib代理 详解

    Java代理机制是Java编程中一个重要的特性,它允许我们在不修改原有代码的基础上,为已有类增加额外的功能。本文将深入探讨两种主要的Java代理实现:JDK动态代理和CGLIB代理。 一、JDK动态代理 JDK动态代理基于接口...

    java代理源码

    Java代理源码主要涉及到的是Java编程中的动态代理和网络代理技术。在Spring MVC框架下,开发者经常使用代理模式来扩展或增强对象的功能,同时,这里的"代理.war"文件表明这是一个Web应用程序,通常用于部署在如...

    Java代理学习

    通过深入理解这两种代理方式,开发者可以更好地利用Java代理机制来优化代码结构,实现更复杂的业务需求。在实际项目中,结合AOP框架如Spring AOP,可以进一步简化代理的使用,提高代码的可维护性和复用性。

    java 代理例子 -javaagent,premain方式实现

    Java代理是一种在运行时增强或拦截对象方法调用的技术,它可以让我们在不修改原有代码的情况下,为类添加新的功能或行为。在Java中,代理主要分为两种:静态代理和动态代理。静态代理是通过手动创建代理类来实现的,...

    Java 代理 代理模式 静态代理与动态代理 常见的动态代理实现 .md

    ### Java 代理模式详解 #### 1. 代理模式概览 代理模式是一种设计模式,主要目的是为了控制或提供对某对象的访问。在代理模式中,代理对象充当客户端与真实对象之间的中介,使得客户端可以通过代理对象间接地访问...

    Lotusscript java代理自动下载指定路径文件

    Lotusscript java代理自动下载指定路径文件。可批量下载指定路径

    Java代理模式模板代码,包含动态代理与静态代理

    Java代理模式是一种设计模式,它允许我们为一个对象创建一个代理,这个代理对象可以在不影响原始对象功能的基础上,增强或扩展其行为。代理模式在软件开发中广泛应用,例如用于权限控制、事务管理、日志记录等场景。...

    java 代理模式详解

    总结一下,Java代理模式的核心在于`Proxy`类和`InvocationHandler`接口,它们共同实现了在运行时动态创建符合特定接口的代理对象。通过代理,我们可以在不修改原始对象代码的情况下,添加额外的功能或者控制对原始...

Global site tag (gtag.js) - Google Analytics