先把上文的连接给大家
将Spring推下神坛(仿造一个中国式Spring ,教大家一步一步从代码的角度理解 Ioc)
表示延续
然后我将谈谈本文到底要写什么东西。我们将从代码的角度去揭开AOP的面纱,这个姑娘真不差,
本帖子也是没有什么高深的东西,也许会继续刺痛那些拿概念吓唬人的高人,请继续飘过,谢谢(五月花,是个大酒家,这里的XX真不差.....)不知道大家有没有看过这集 “综艺大哥大”
本文的目的是不要更改用户代码,把AOP的概念加到我的Dong里面去,还是先把目的写出来吧
也许着就是测试用例驱动开发的一种体现
1.在方法开始的时候输出 函数名 开始时间
2.在方法结束的时候输出 函数名 结束时间 以及 方法 花费 的 时间
然后再次贴出我的贴图,表明结果

成功完成。
这时候,也该看看我是如何完成的吧,请注意黑体字的内容
其他代码和上篇相同,这里添加了一个新的类
1.EventHandler.java
========================================================================
package org.dong.core;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.util.Date;
public class EventHandler implements InvocationHandler {
???
??? private Object delegate;
???
??? public EventHandler(Object delegatec)
??? {
?
?? ??? //把需要代理的物件传进来??? ??? this.delegate = delegatec;
??? }
???
??? public Object invoke(Object proxy, Method method, Object[] args)
??? ??? throws Throwable {
??? ???
??? ??? Object obj = null;
??? ???
??? ??? long startTime = System.currentTimeMillis();
??? ???
??? ??? //做之前 我可以加一些代码,这里就是功能实现的地方
??? ??? Date dt = new Date();
??? ??? System.err.println(method+"begin"+" @ "+dt.toString());
??? ???
??? ???
obj = method.invoke(delegate,args); //嘿修,我XX,代理的过程??? ??? //做之后,我也可以加一些代码
??? ??? dt = new Date();
??? ??? long endTime = System.currentTimeMillis();
??? ???
??? ??? System.err.println(method+"end"+" @ "+
??? ??? ??? ??? dt.toString()+ "time "+(endTime - startTime)+" ms");
??? ??? return obj;//把做完的踢出去,嘿嘿
??? ??? ?
???
??? }
}
然后我修改了相应的BeanFactory实现类,来完成我们的功能
package org.dong.core;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Proxy;
public class XmlBeanFactory implements BeanFactory {
??? private String ResPath;
??? private static DongXmlOp XmlOp;
??? public XmlBeanFactory(Resource Res) {
??? ??? ResPath = Res.GetResPath();
??? ??? XmlOp = new DongXmlOp(ResPath);
??? }
??? public Object getBean(String string) {
??? ??? Bean tmpBean;
??? ??? tmpBean = XmlOp.GetBeanByID(string);
??? ??? try {
??? ???
??? ??? ??? Class rtnClass = Class.forName(tmpBean.getBeanClass());
?
?? ??? ??? //tempBean.getBeanClass()="user" or "userNew" in the DongContext.xml ??? ??? ???
??? ??? ??? //好了,在这里我们将实现 AOP,把我们到底干了什么给 print出来?*_*????????????
??????????? Object rtnInstance= rtnClass.newInstance();
??? ??? ??? //这里是最重要的一句话,反射的精髓
??? ??? ???
??? ??? ??? //看到这里了么,动态代理被我们包括到了我们的Dong里面,完全没有改动用户代码哦。
??? ??? ??? InvocationHandler handler = new EventHandler(rtnInstance);
??? ??? ??? Object rtnInProxy=??? Proxy.newProxyInstance(
??? ??? ??? ??? ??? rtnInstance.getClass().getClassLoader(),
??? ??? ??? ??? ??? rtnInstance.getClass().getInterfaces(),
??? ??? ??? ??? ??? handler);
??? ??? ??? //动态代理的实现
??? ???
??? ??? ??? //记得我们原来直接就把 rtnInstance 踢出去了么,这次我们代理了以后把代理踢出去了。
??? ??? ??? return rtnInProxy;??? ??? ???
??? ??? } catch (Exception e) {
??? ??? ??? System.err.println(e);
??? ??? }
??? ???
??? ??? return tmpBean;
??? }
}
posted on 2006-04-26 14:13
寒晴天 阅读(217)
评论(9) 编辑 收藏 收藏至365Key