浏览 5197 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2010-01-20
最后修改:2010-01-26
首先我们学习spring AOP之前学一学 传统AOP的实现: 我们的需求是这样的: 1,判断用户不为空(user!=null)时执行业务代码 2,拦截所有业务方法 这样我们传统的方法是每个业务方法里面判断user是不是null值(假设这样的判断有足够多),这样一来随着我们的业务方法的增多判断语句也随即多起来,那我们又没有跟好方法避免这个情况呢? 设计模式--Proxy 客户端-------》代理对象------》目标对象 首先我们提供一个interface package javaeye.service public interface PersonService { public void save(String name); public void update(String name, Integer personid); public String getPersonName(Integer personid); } PersonService 接口的实现 package javaeye.service.impl; import javaeye.service.PersonService; public class PersonServiceBean implements PersonService{ private String user = null; public String getUser() { return user; } public PersonServiceBean(){} public PersonServiceBean(String user){ this.user = user; } public String getPersonName(Integer personid) { System.out.println("我是getPersonName()方法"); return "javaeye"; } public void save(String name) { System.out.println("我是save()方法"); } public void update(String name, Integer personid) { System.out.println("我是update()方法"); } } 用jdk提供的代理类Proxy 来实现 实现这时候PersonServiceBean 类必须实现PersonService接口 package javaeye import java.lang.reflect.proxy; public class JDKProxyFactory implements InvocationHandler{ private Object targerObject; public Object createProxyIntance(Object targetObject){ this.targetObject = targetObject; return Proxy.newProxyInstance(this.targetObject.getClass().getClassLoader(), this.targetObject.getClass().getInterfaces(), this); //jdk里面的 Proxy.getProxyClass(loader, interfaces). getConstructor(new Class[] { InvocationHandler.class }). newInstance(new Object[] { handler }); //在这里用Proxy.newProxyInstance来创建代理类,第一个参数是目标对象的类装载器,第二个参数是我们的代理对象要实现的接口那一些,我们实现的是this.targerObject的所有类,第三个参数是回调函数(this是本身),如果这样必须继承接口 InvocationHandler //Object java.lang.reflect.InvocationHandler.invoke(Object proxy, Method method, //Object[] args) public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { PersonServiceBean bean = (PersonServiceBean) this.targetObject; Object result = null; if(bean.getUser()!=null){ try { result = method.invoke(targetObject, args); //把方法的调用委派给目标对象 } catch (RuntimeException e) { }finally{ // } } return result; } } 测试 @Test public void proxyTest(){ JDKProxyFactory factory = new JDKProxyFactory(); PersonService service = (PersonService) factory.createProxyIntance(new PersonServiceBean("xxx")); service.save("javaeye"); } 下一章是关于动态代理的实现 --》cglib 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2010-01-21
学过,不过忘得差不多了。现在做的不是这些东西。。不过还是有一些思想吧。
|
|
返回顶楼 | |
发表时间:2010-03-18
代理这玩意儿真的好复杂
|
|
返回顶楼 | |
发表时间:2010-03-19
最后修改:2010-03-19
最经也在看AOP这块
代理就是通过在调用目标对象的时候 一些操作 |
|
返回顶楼 | |
发表时间:2010-03-27
最近项目改版, 利用了spring的 aspectj . 对此有了一点点了解.
有对此感兴趣的可以联系我. 相互交流下. |
|
返回顶楼 | |