学习WebX的一些小心得
加入淘宝实习已经两周了,最近在学习webx框架,之中发现了一下问题拿出来给大家分享一下:看看如下的Screen 代码,搜索所有的xml,都没有发现HelpBrowser 出现在配置文件中,而其中的 helpContentAO 是在spring的配置文件中找到的,那么webx是怎么将helpContentAO 注入到HelpBrowser的呢?
我们在set方法处插入断点,重启jetty服务器后发现,只有第一次请求时才会执行到断点处,在栈帧上寻找,发现了一个关键方法:injectDependences();
下面让我们就来看一下,它是怎么将 对象注入的,这和spring的注入又有什么区别呢?
在方法中插入断点后,我们发现了参数moduleClass 就是待注入的类Class:
反复调试,我们很快就发现了我们正在寻觅的 HelpBrowser 类:
从类Class 获得属性名后 ,不难获得 Setter :
然后就到了我们最关心的问题 helpContentAO 对象从哪儿来,怎么注入的;
就在此方法体 继续调试源代码,很快就到了获得helpContentAO 的关键方法:
Resolver 是 谁,它从哪儿去取,我想第二个问题相比要好回答一些:肯定是从spring的容器里去取,但resolver到底是什么东东,它和spring容器又是什么关系呢?!让我们进去方法体去一看究竟:
我们先不管resolver是谁,它依赖了 moduleResolver,而moduleResolver又是谁呢,这里它的实例叫SpringReferenceResolver对象。
再进入方法体,我们就知道了原来是 同级的BeanFactoryService在帮忙:BeanFactoryService 是实现Service接口的接口,整个webx2.0
基于Service框架,所有组件都需要实现Service接口,统一管理,而这里他的实现类是:
这里它就是webx 对Spring容器的包装类。
同样的方法名,我们在简单深入两层,你就会看到我们大名鼎鼎的 AplicationContext :这下真相终于大白了
由此我们可以看出,Spring真的可谓是轻量级框架,在BeanFactoryService中,其实启动启动Spring只需要一句话:new一个BeanFactory;
然而,Webx 对spring的封装得很透明,但如果太透明话就会让用户对一些自动的处理感觉莫名其妙。
为什么我们的架构设计师会这样设计呢?
原来,返回代码的顶端,@注释给我们揭晓了答案:
“Spring自从2003年发布以来,一直是Java开源框架的奇迹之一……2004年到2006这三年时间以来,Spring取得了相当辉煌的成就,不但将EJB2赶进历史,而且牢牢确立了Spring作为Java企业应用开发的主流地位。”
2006 年!这个对Spring的包装类是06年才发布的,而webx2.0在2004 就已经抛弃了发展缓慢的Turbine开源项目,重新全写发布;当时Spring 才刚发布一年(“Spring自从2003年发布以来”)而恰好是在 2006 年 Spring将EJB2赶进历史,牢牢确立了自己作为Java企业应用开发的主流地位。可见spring是后来才作为一个组件加入进来的。
以前都是听说spring整合其他框架,这次它自己被整合了!^_^
到了 2010年,看看webx3.0 :“2010年,Webx 3.0发布。Webx 3.0抛弃了Webx 2.0中过时的、从Turbine中发展而来的Service框架,直接采用Spring作为其基础,并对Spring作了重大改进。”结果果然不出我们所料。
^_^ 完
页:
[1]