在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 是一种基于Notes技术的服务器端应用程序, Lotus Domino Java 代理是指在 Domino 服务器上运行的 Java 代理程序,可以用来处理用户请求、提供数据服务等。今天...
Lotus Domino是一个企业级的应用开发平台,而Java代理在Lotus Domino中被用来处理服务器端的任务,例如数据处理、业务逻辑或响应HTTP请求。在这个特定的案例中,`JQueryReportToolJavaAgent`是一个Java代理,它被...
在Lotus Domino开发环境中,Java代理是用于执行服务器端任务的重要工具,它们可以自动化许多功能,如处理数据、发送邮件等。"lotus domnio java代理传值"这个主题主要涉及如何在Java代码中创建和使用代理,并在代理...
### Java代理模式与Java动态代理详解 #### 一、代理模式概述 代理模式是一种软件设计模式,它在客户端和目标对象之间提供了一种间接层。这种模式的主要目的是控制客户端对目标对象的访问,并且可以在不修改原有...
本文根据java代理实现CXF拦截器异常时只能进入fault拦截器而不能继续向下执行的问题。 利用java代理让RMI具有拦截器的功能。
本教程将聚焦于如何利用Java代理来实现Excel文档的导出。 Lotus Domino是一款强大的协作软件,它提供了丰富的开发环境,包括服务器端的LotusScript和客户端的JavaScript,但在此场景下,我们使用的是Java代理,因为...
在 Lotus Domino 中,Java 代理是可以运行在 Domino 服务器上的小程序,它可以执行特定的任务,如获取当前用户名。 在 Java 代理中,获取当前用户名是一个常见的需求。 Lotus Domino 提供了多种方式来获取当前...
Java代理模式是一种设计模式,它在面向对象编程中扮演着重要的角色,主要目的是为了在不修改原有对象的基础上,为对象添加额外的功能或者控制对对象的访问。代理模式的核心思想是通过代理类来间接调用目标类的方法,...
Java代理模式 事例很生动,非常容易理解,推荐给大家。
java 代理服务源码 测试通过可以,可以自己修改成为自己的代理类。
Java代理服务器程序是一种用于转发网络请求的应用,它在客户端与目标服务器之间起到中介的作用。这样的设计使得用户可以通过代理服务器访问互联网,从而实现多种功能,如匿名浏览、负载均衡、缓存优化、网络监控等。...
Java代理机制是Java编程中一个重要的特性,它允许我们在不修改原有代码的基础上,为已有类增加额外的功能。本文将深入探讨两种主要的Java代理实现:JDK动态代理和CGLIB代理。 一、JDK动态代理 JDK动态代理基于接口...
Java代理源码主要涉及到的是Java编程中的动态代理和网络代理技术。在Spring MVC框架下,开发者经常使用代理模式来扩展或增强对象的功能,同时,这里的"代理.war"文件表明这是一个Web应用程序,通常用于部署在如...
通过深入理解这两种代理方式,开发者可以更好地利用Java代理机制来优化代码结构,实现更复杂的业务需求。在实际项目中,结合AOP框架如Spring AOP,可以进一步简化代理的使用,提高代码的可维护性和复用性。
Java代理是一种在运行时增强或拦截对象方法调用的技术,它可以让我们在不修改原有代码的情况下,为类添加新的功能或行为。在Java中,代理主要分为两种:静态代理和动态代理。静态代理是通过手动创建代理类来实现的,...
### Java 代理模式详解 #### 1. 代理模式概览 代理模式是一种设计模式,主要目的是为了控制或提供对某对象的访问。在代理模式中,代理对象充当客户端与真实对象之间的中介,使得客户端可以通过代理对象间接地访问...
Lotusscript java代理自动下载指定路径文件。可批量下载指定路径
Java代理模式是一种设计模式,它允许我们为一个对象创建一个代理,这个代理对象可以在不影响原始对象功能的基础上,增强或扩展其行为。代理模式在软件开发中广泛应用,例如用于权限控制、事务管理、日志记录等场景。...
总结一下,Java代理模式的核心在于`Proxy`类和`InvocationHandler`接口,它们共同实现了在运行时动态创建符合特定接口的代理对象。通过代理,我们可以在不修改原始对象代码的情况下,添加额外的功能或者控制对原始...