新年,2005总结再见,欢迎2006来临!

2005年是我的本命年,其间很多事情发生了改变,人生收获颇多。所以,这里几个流水账,自勉。

 1、年初和期末考试作斗争,并且成功全过。这门过后我的学分基本修够,减少了下个学期的专业课学习压力,是个成功。

 2、第四次冲击6级。靠,我个人非常清楚英语的重要性,所以一直注意实际阅读、听的能力,但是六级的应试能力不佳。幸好zz帮助我,给我找了些真题,而且教导我要向过6级就好好做真题。结果顺利通过,真是喜出望外。今年是老版6级最后一年了,算是赶上这个末班车了。谢谢zz。

3、陪zz准备北京公务员考试,本来说陪她考的,可是由于时效问题,没有真正陪她,也没有好好帮她复习。她没过。这是个失败,明年要陪她冲击。

4、学校第二学期开始,开始一段比较自由的学习。我开始认真地读《程序员杂志》,为自己从硬件兴趣型到软件专业型的转换做准备。经验是,不管如何要专业。

5、和小梁合作的jsp的电子商城项目被我们强行终结,幸好将我们将货款收回。这个项目我们从去年9月做到今年3月,成本亏了是肯定的,但是让我从一个asp程序员转型为jsp程序员,真正了解脚本是什么。呵呵,我的asp还是2年前在玩票,现在的jsp让我慢慢往后了解server可以如何运作。这里不多说了。但是这真的是个正式的算钱的项目,体会了软件工程,学习了如何分工协调,从我的搭档身上也学到了很多,我的学习能力在这个项目上迅速提升。

6、做了几个网站,包括给小叔公司代理telecobriges,还有大学同学的《厅长小武》,还有一个Moshiwig假发。基本上是设计型的,分别对PSD切片、xhtml+w3c等进行了更多的尝试。

7、五月和zz去青岛旅游,太高兴了,充满无数美好回忆!所以明年还要继续选择一个目的地去旅游。

8、进行二级实践课程,认识了几个好朋友,与他们的共事使我真正进入Java Web开发的阵营,并且用心的体验了什么是轻量J2EE开发,真正认识了Spring、Struts、Hibernate,几乎是一夜间我就成为了一个Javaer。

9、上了软件心理学,并认真思考了一下UI设计的问题。虽然没有上升到学术高度,但是确实认真思考了这方面的问题,感觉很有收获。

10、开始研究什么是架构,什么样的需求需要什么样的架构。多次和LBBZH讨论过这些问题,感觉收获巨大,他是个好朋友,以后还要多向他学习。

11、开始用业余时间在混乱的开源项目中体验不同的思路,从而可以在简历中说熟悉了一大堆的框架、工具等等。发现开源社区的意义,并尽量做些贡献(eXtremeComponents、参与翻译Pro Spring等)。这种感觉是快乐充实的。

12、协助一个朋友忙开网吧的事,并出差山东一次。虽然时间不长,但这种只身去陌生地方的经验是第一次,男人需要成长呀。

13、今年第一次自己找了个工作。得到了一个朋友的帮助。工作了不到两个月,平生第一次正式的领到工资。虽然在单位没有发挥自己的全部实力,但是还是认真地做事,可惜单位的职位还是不太适合我,我需要一个空间让我自由发挥。但是单位的同事都是朋友拉。谢谢丸子!

14、今年也第一次尝试了辞职。仅仅工作了两个月就被朋友召唤走了,心里没有一丝依恋。因为新的环境会很自由!辞职的流程还是比较长经验的,哈哈。

15、和朋友组成Team去密云做工程,我的职位是系统架构师。非常惭愧,其实不配这个称号。但是被人家吹捧的感觉还是不错的,谢谢你们的善意欺骗,我会努力成为真正的master的。

16、终于有足够的money陪zz逛街了,很爽。尤其是可以不假思索的说“拿下”,看zz惊讶的笑脸,满足啊。男人就应该这样,明年继续。

17、我和zz终于走到一个里程碑,我们已经计划好,她已经同意嫁给我了。具体的计划还在筹划,这是我人生中的重大决定呀。

18、今年花了很大的心思给zz准备生日礼物。她非常满意。男人应该尽到他的心意。zz,我喜欢给你画画。

19、今年在硬件上。我花eShop工程和小武等工程的钱买了个Dell 1704FPT LCD,并且通过我的努力将有坏点的显示器换成了一个完美的8ms板的。当然1704颜色一般,准备以后换个好的。后来入手了Logitech G5和MX510两个鼠标,键盘变成了Dell 8135。其余的新鲜东西没啥了。

20、年底送给zz一个iPod nano黑色。原先跟她说她并没有感兴趣,但是送她以后她却被它迷住了。她超级喜欢这个礼物,个人认为这礼物是我的杰作。同时送了iDog小狗一直,完全满足我家zz的爱好!

21、由LBBZH推荐加入了BJUG,参与了几次活动,受益匪浅。对各位大牛真地是佩服得五体投地,并且也迅速找到了自己的不足。更加认真地扎入到java这个阵营中了!学习了更多的框架,理解也比以前深刻了,明年还要继续跟进。

22、今年丢了一次钱包,卡没有使用强密码,损失了800元。还好先前花980买了个Meizu E5 512MB Mp3,它给我带来了很多的音乐享受,也让我少丢了另外800元钱。明年要涨记性,多注意防贼!

23、我的三星X108丢失在青岛的崂山风景区,具体丢失过程不明,但是以后还是要多家小心。 好了,23是我的幸运数字,不继续写了。

可以说2005年是我到现在的人生经历中收获最大的一年。学习平稳到了一个收获期,成功转型,成功潜入Java开发阵营并站稳脚,感情稳定并得到认可,经济状况明显好转,性格也成熟了很多,我真的从一个男孩成为一个准男人了。明年的目标就是更男人!要更男人就是为了要扛起我的父母和爱人。期待2006,一定要比2005更加充实。

Spring 2.0和给贫血模型充血

Spring 2.0 vs. the Anemic Domain Model
原来是因为老马骂了贫血模型为反模式,说冲血模型才是最好的,能够真正的OO。
不过Spring 2.0的概念被骂了个体无完肤。
本身,我的立场从来就没有站在OO这一边,我是真的无所谓的人,什么过程、OO、FP我都很认同,当然能优雅些是最好的。
看了以后就想到WQH前两天就已经推荐给我的ajoo写的充血模型的问题,我才意识到QH大师又走在我们前头了!
看了下javaeye上贫血/充血的讨论,才豁然开朗。
知道为什么冲突就对了。关键点还是在争吵OO,而OO在领域模型方面有时适合充血有时适合贫血,当然贫血居多,所以举起例子总是两边倒,没有定论。
还好,抽出重要部分,对于基本CRUD,那么绝对是贫血模型就好了。而对于有复杂计算的领域模型,我们要建立一个完备的OO的领域模型则需要充血。
这提醒了我们,充血的确是需要的。不过给Hibernate下的POJO(明显贫血到死)充血并不容易,所以才有了更多的文章讨论这个问题。
记录下来,大家有兴趣一起研究:
TSS:Spring 2.0 vs. the Anemic Domain Model
http://www.theserverside.com/news/thread.tss?thread_id=38047
Javaeye论坛:贫血就贫血,咂地?
http://www.hibernate.org.cn/viewtopic.php?p=100045&sid=df2163b2c94afbb6b214da6b3be42d73
ajoo在javaeye的conflunce上写的:怎样给马丁的充血域对象注射依赖
ajoo一文的后篇:http://www.javaeye.com/display/ajoo/Dependency+Injection+For+Rich+Domain+Model
对程序员透明的非aop方法解决rich domain object的依赖注射
http://www.javaeye.com/display/ajoo/Transparent+Dependency+Injection+For+Rich+Domain+Model
Codehaus上的一个解决方案:Dependency Injection For Rich Domain Objects
http://docs.codehaus.org/display/YAN/Dependency+Injection+For+Rich+Domain+Objects
老马写的批评贫血模型的檄文:AnemicDomainModel
http://www.martinfowler.com/bliki/AnemicDomainModel.html
Spring Blog上的原文:Spring 2.0 vs. the Anemic Domain Model
http://jroller.com/page/habuma?entry=spring_2_0_vs_the
我个人认为POJO还有DTO都是简单的VO,而VO就是VO,要区别于Real Object。我们的domain里面大都是VO而不是RO。Hibernate也是基于VO的,EJB3同样。所以RO应该说是理想OO下的东西,我们真正要用的时候,还是可以自己选择是否要实现这种复杂的东西的。但是不用RO则我们的程序就变得过程化。所以老马也认为这是头疼的事,但又不要解决,只能放到他的TODO list里面了,哈哈。
哈哈,但是看完Spring的那个Blog,感觉Spring 2.0做好了解决多向以来的模型的方法是很不错的,当然是由解决给贫血模型充血引发的,但是我认为它还能解决其它问题,所以感觉不错。但是Spring 2.0再次强调Aop的好处,也的确能看到,所以有时间还要学习一下AspectJ。
而这个问题ajoo说了IoC和Aop都可以解决,感觉各有道理。IoC方式感觉代码容易读懂,也合理。而Aop则代码有点牵强,当然使用起来感觉很爽,尤其和Lazy-init结合,对生存周期的控制有它读到的地方,而且想明白了用Aop+Annotation感觉也很清楚优雅。

非常完美的一天!

早晨,刚刚睁眼听到妈妈说7:05了。昨晚和ZZ说好了今天8:00去她家找她。所以麻利的起来穿好衣服,洗漱干净背上书包冲出家门。爱人的召唤吸引着我,脚步十分轻快。
和每个找她的周末的早晨一样,习惯性的期望13路正好经过,因为搭乘13是去她家的最佳车辆。作为完美一天开始的信号,我看到十三路从远方开来,并且面前是个绿灯,可以马上过马路到车站。快步冲过人行道,我与车一同停下,上车,心情很愉快!
我在锣鼓巷倒车,换乘115路。下车继续用我喜欢的节奏快步前行,到了115路总站发现刚好就要发车,小跑几步上了车,还坐在我最喜欢的皇帝位上。皇帝位就是最后一排最中间的那个坐,视野广阔,可以面对整个过道,拥有清晰的视野是让人心情轻快的事。
8:05分,我已经在ZZ家楼下。天太冷了,我走到ZZ家的楼道中,此时她已经收到了我到达的讯号,因为我听到她家的门被打开又被关上的声音,多么熟悉呀,说明我家宝贝已经就要下来了。
然后就是蹦蹦跳跳的下楼的声音,我迎上去,我家ZZ看来很高兴,她在看着我开心你的笑。我抱起她,一直到楼下。
按我们的计划上午有个健身的活动,我们搭车去了KFC,吃些早餐。要了咖啡和麦香猪柳蛋的组合。这个选择很英明,芝士ZZ很喜欢,而蛋的口感很顺华,猪柳则明显调和了清淡的口味,配合在一起就能给我们满足的感觉。然后就是期待中的一小段运动时间,现在健身已经是我们生活中的一个重要节目了,因为现在的生活节奏的确需要这种节目来缓解,边运动边聊天。
ZZ说昨晚吃的太少了,尽早就很饿,刚才的早餐其实大部分被我干掉了……ZZ说要计划一下中午吃什么,她想吃好的。
什么叫说曹操曹操就到?在完美的一天一定要有这样的巧合才对。就在我们计划吃什么的时候收到了姐姐发来的短信,问我们在哪里。嘿嘿,姐姐周末的短信就是说要有饭局了。
正好中午要去国展家乐福,就应了姐姐……中午去吃汉拿山,上次就说请姐姐吃的,正好也是ZZ的最爱之一。而我正好是无肉不欢的人,当然乐意的不得了!
饭局定在12:00。我和ZZ先去国展家乐福,这里的特点就是物种极大丰富,我们并不喜欢这里火车般的长队,但是喜欢到这里发现没见过的食物,这种感觉有点像在逛博物馆。
由于时间仓促,我们主要流连于西餐区,因为ZZ总想给我做pasta吃,前一天其实我们已经来过,不过还没有过瘾,我们继续寻找各种pasta的佐料(昨天已经买了通心粉和番茄肉酱),真的很好玩。很快接到电话,二姐的车到了。
我们两个迅速跑出去了,活像两个企鹅,哈哈,摇摇晃晃跑过过街天桥。
去吃汉拿山了。可爱的明明没来,哥哥点的菜。这里的牛扒还是那么好吃,让人感觉幸福呀。腐败的过程不赘述,吃完以后我们来到安贞华联。
ZZ想要兰寇的so magic香水,可惜这里没有兰寇。然后我们逛啊逛,终于逛到了海盗船,那天答应送她一个新耳环。其实她扎了耳朵眼没几天,现在还没好利落呢,前几天送她了一对耳钉,她还想要环。
到了店里,她在挑……我用眼扫了一下,发现一对比较闪亮的,好像在呼唤我。我推荐给ZZ,她一下就喊道:“太漂亮了!”然后她也环视了一下,马上肯定我选到的是最漂亮的,然后说我要买下它。
我非常干脆利落的让小姐开票并去付账了,这是我最近练出的本事,做男人给女朋友花钱一定要买单不眨眼不犹豫,说实话也没什么犹豫的,我喜欢她闪亮亮的。
回来的时候她已经把耳环换好了,看着她闪动着满意的眼神,我心里十分的满足,嘎嘎嘎!
然后继续逛,卖首饰的柜台真多,不过没怎么看到更好看的。所以说是完美的一天,因为想要的东西马上就可以找到!
我们继续逛,她给我指了很多毛衣,可能我很想给她买东西,并没有看到什么让我眼前一亮的毛衣。我现在也变挑剔了,因为要让她有面子我也要打扮得潇洒一些,前年这个时候我可不会逛商场买衣服,但是现在,逛商场感觉就像在自己家里一样。
下了楼,本来要回家了,看到国美电器了。她想起要买个卷发棒,其实去年她就要求过我,可是看到的都太低档了,所以还没出手。
进去以后,很快选定了德国伟嘉的3合1卷发棒,我坚持要送给她!她欣然接受,我很满足,嘻嘻。
然后过了马路,718很快到站,然后又很快有坐。到了家里,有香喷喷的牛肉面等我们爽呀!
爽呀!爽呀!爽呀!爽呀!
真的很满足,因为很完美,我们已经找到了应该收集到的所有快乐碎片,下一步就是步入婚姻殿堂了,她也欣然接受,我就要订婚了,当然日程还没有订!
所以,这是需要纪念的一天!
2005年12月11日!

关于事务的满脑袋酱子,解惑:本地、JTA、CMT

传统上J2EE有两种事务管理策略:全局或者本地事务
全局的由app server保证,如JTA。而本地则是针对某种资源的,如JDBC连接的事务。
其中,全局事务是为了保证多种事务资源的共同工作。但是如果是用本地的事务,则容器(app server)无法保证跨资源的事务。
JTA是一种全局的事务。但是JTA是笨重的,且JTA的事务一般需要通过JNDI获得,所以JNDI和JTA一般联用。而且JTA代码一般不能跨App server,会受限于某种特定的容器。
所以更好的方式是使用EJB CMT(Container Managed Transaction),它的特点是使用声明性事务,而不是编码事务管理。
所以,虽然EJB天然结合了JNDI,但是并不受限于容器(声明性)。
但是CMT又依赖于JTA和App server环境(或者说支持EJB的App server,Tomcat这些Servlet容器就不行啦)。所以这种事务如果依赖于EJB或者EJB的装饰封装则要花不少资本投资App server(不是钱也至少要人,如JBoss)。
但是,我们还有更好的选择,如Spring,或者很多Aop实现,EJB3等等。
而本地的事务策略虽然实现容易,但是缺点显著。它不能在多资源间实现事务支持,并且这种事务对变成模型的侵入也很大(传统JDBC事务使用起来就是这样)。而且如JDBC连接也不能与其他JTA事务协同被管理。如你的JDBC和某个其它事务绑定(如两个JDBC Connection)起来,如果遇到一个失败你如何将两个rollback?(这个是我自己演绎的)
下面是广告:
Spring解决了这个问题。它提供了一个持续的模型,可以应用在大多数环境。也就是说你可以灵活的更换它支持的各种事务策略(你也可以自己扩展)。而且Spring两种方式的事务都支持(声明/编码),当然Spring推荐使用声明的(侵入小,灵活)。

MB,本来写了不少体会,结果倒霉没有保存,如果有时间我再考虑一下是否重写吧,损失惨重!

我不再让你孤单

很少去KaraOK的,但是每次去的时候都回唱这首歌。
因为我实际唱得出的歌没有那么几首,这首很久之前我就非常喜欢,就好像是我自己要说的话。现在我很喜欢给她唱这首歌,因为看着她的脸唱这首深情的歌,就好像在念一首诗。
在她的朋友面前唱过这首歌,看着我唱歌时他们投降她的羡慕的目光,我心里也是暖暖的,因为这本就是应该献给你的——我最爱的宝贝!
她经常夸奖我大声唱时很感人,她说我唱的很好听。也许我不优雅的嗓子适合唱陈升这种Blackguard的歌吧。
甜蜜的时间是没有尽头的,当然这需要学会Free,虽然我不Free,但很大的时间我却可以体会到那种甜蜜,简单的满足。
所以,当今天我在一词听这首歌的时候,哼起它:
让我轻轻的吻着你的脸
擦干你伤心的眼泪
让你知道 在孤单的时候
还有一个我 陪着你
让我轻轻的对着你歌唱
像是吹在草原上的风
只想静静听你呼吸
紧紧拥抱你 到天明
路遥远 我们一起走
我要飞翔在你每个彩色的梦中
陪着你
我从遥远的地方来看你
要说许多的故事给你听
我最喜欢看你胡乱说话的模样 逗我笑
尽管有天我们会变老
老得可能都模糊了眼睛
但是我要写出人间最美丽的歌 送给你
路遥远 我们一起走
我要飞翔在你每个彩色的梦中
对你说 我爱你
WOO……
我不再让你孤单 我的风霜你的单纯
我不再让你孤单 一起走到地老天荒
我不再让你孤单 我的疯狂你的天真
我不再让你孤单 一起走到地老天荒
路遥远 路遥远
我不再让你孤单
所以,宝贝,我不再让你孤单!

实验Webwork2.2与Spring的Auto-wire (2)

太长了,这是下半部分。

我做了一下小实验,以Webwork2的样例程序为例:

原先只在xwork.xml总进行了配置,Spring配置中无该bean

<action

name="main" class="com.opensymphony.webwork.example.ajax.actions.ActiveCategory">

<result name="success">/category-main.jsp</result>

</action>

1、 使用byType方式:这个没什么可说,只要类一样自动就可以匹配,并使用。

添加了Spring中的配置:

<bean id="main_action"

class="com.opensymphony.webwork.example.ajax.actions.ActiveCategory"

singleton="false" />

2、 使用byName方式:在Spring中配置id=”xxx”,然后再xwork中配置name=”xxx”,可以自动匹配,可以使用。

修改了Spring配置如下:

<bean id="main"

class="com.opensymphony.webwork.example.ajax.actions.ActiveCategory"

singleton="false" />

3、 然后删除xwork.xml配置中的class=”com.xxx.xxx”class=””,依然可以工作。

修改了xwork.xml配置如下:

<action name="main" class="">

<result name="success">/category-main.jsp</result>

</action>

4、 然后再实验使用Springbeanname属性进行匹配,依然工作正常。

修改了Spring配置如下:

<bean id="main1" name="main"

class="com.opensymphony.webwork.example.ajax.actions.ActiveCategory"

singleton="false" />

所以,看起来nameid都可以用来auto-wire,所以id如果可以区分,用它来auto-wire就可以了,比较方便。

不过我个人有个疑问,在Spring中声明action是否要生明singleton=”false”?按理说应该false吧,可是我看例子中都没有声明。我记得Spring默认是singleton=”true”的,这是为什么?

实验Webwork2.2与Spring的Auto-wire(1)

前几天看到BJUG的朋友说最近大家都不写技术Blog了,我实在是没看什么东西,今天正好要搞Webwork2+Spring,体验了一下新版本的集成,做了点翻译,还顺道作了点小实验。

基于Spring 1.2.5 + Webwork 2.2 Beta3

1、中文参考是飞云小侠的——《WebWork2.2中结合Spring:"新的方式"》:

http://www.jscud.com/srun/news/viewhtml/4_2005_9/134.htm

2、英文参考是WebworkConflunce上的文章(不好意思,基本上是翻译这篇文章):

Enabling Spring Integration

http://wiki.opensymphony.com/display/WW/Spring

3Other Spring Integration

http://wiki.opensymphony.com/display/WW/Other+Spring+Integration

其中:

webwork.properties中通过这条设置打开SpringObjectFactory

webwork.objectFactory = spring

而修改autoWire的工作方式则通过这个设置:

webwork.objectFactory.spring.autoWire = type

autoWire其实就是webwork寻找Spring已经创建的bean的方式,有如下四种方式可以设置:

name

通过对Spring中的beanname与你程序中的actionname属性进行匹配。系统默认使用这种方式(如果不写上面那句的话)。

type

通过在Spring中注册的bean中寻找与你程序中的actionname相同的属性来匹配。这需要保证Spring中一个类只能注册一次(即不允许部同名但同类的Spring配置)

auto

Spring试图自动检查最好的Auto-wire方式。

constructor

Spring会根据constructor的参数来匹配action。(webwork这里没有作更多说明,根据Spring的规则,这种方式应该与type类似,只不过这里不是匹配setter,而是匹配constuctor的参数。)

其实,看看Spring的相关书籍,其实这就是Spring的四种Auto-wire方式,分别对应:byNamebyTypeautodetectconstructor。可以参考Pro Spring的第4章的内容“Auto-Wireing Your Beans”。

然后说明了一下方式,配置了auto-wire以后每次都回试图通过Spring来匹配对象实例。如果Spring没有创建这个Bean,那么Webwork会自己创建它。同时,要在web.xml中注册SpringLisener来打开这个功能:

<listener>

<listener-class>

org.springframework.web.context.ContextLoaderListener

</listener-class>

</listener>

这里Webwork提出了一个提示:需要更多的ApplicationContext配置文件么?

如果使用了Spring的标准Listener来结合,那么可以除了aaplicationContext.xml还配置多个xml配置文件。可以通过下面的配置来实现,需要加到web.xml里面。

<!– Context Configuration locations for Spring XML files –>

<context-param>

<param-name>contextConfigLocation</param-name>

<param-value>

/WEB-INF/applicationContext-*.xml

/WEB-INF/spring-daos.xml

/WEB-INF/spring-actions.xml

</param-value>

</context-param>

这个可以参考Spring文档。

Spring中的配置样例

这里,你可以添加标准的Spring配置文件,在WEB-INF/applicationContext.xml。下面是一个例子:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">

<beans default-autowire="autodetect">

<bean id="personManager" class="com.acme.PersonManager"/>

</beans>

从使用内建IoC转移到使用Spring

转移很容易。Spring的配置就如上所述。完成融合,你需要:

1、 将你的components的配置从components.xml适当转移到applicationContext.xml。然后就可以安全的删除components.xml了。

2、 xwork.xml的拦截器栈(interceptor stack)中移除Component Interceptor。虽然不移除也无伤大雅,但是留下它已经是个冗余了。

Session ScopeSpring

Spring目前不支持session scoped components。不过计划在Spring 1.3 release中整合该功能。现在,你必须使用Spring Session Componnets Workarounds

Spring中初始化Actions

一般,xwork.xml指明了每个Actions的具体类。当使用SpringObjectFacotry(如上面配置的过程),意味着将通过Spring来创建action,然后来组装(wire)他们之间的依赖,根据设定的auto-wire行为。SpringObjectFactory将会应用所有的预处理工作,例如代理你的action的事物(transactions)、安全(security)、等等。这样不需要明确配置,Spring会自动装配它们。大部分应用中,这就是你所要做的全部工作,使你的actions的服务和依赖关系被执行。

我们强烈建议使用声明的方式来让Spring知道你的actions之间的依赖。这包括自动的装配具有相同的name的属性和bean(就是指byNameAuto-wring),或者byTypeAutowire(这种情况下一个类型只能在Spring中注册一次)。或者还可以使用JDK5种的annotations来声明事物或者安全的配置,而不是通过applicationContext.xml,这样你就不需要在所有配置文件来维护它们了。

然而,有时你想让bean通过Spring自动管理。这很有用,例如,如果你想配置复杂的AOP或者Spring支持的技术到beans上,例如Acegi。这样,你需要将所有的配置写到applicationContext.xml里面,然后改变WebWork action中的class属性,使之与Spring中的bean name定义相同,代替原来使用的真实类名。

你的xwork.xml文件中的class属性会改变,就像下面这样:

<!DOCTYPE xwork PUBLIC "-//OpenSymphony Group//XWork 1.0//EN" "http://www.opensymphony.com/xwork/xwork-1.1.dtd">

<xwork>

<include file="webwork-default.xml"/>

<package name="default" extends="webwork-default">

<action name="foo" class="com.acme.Foo">

<result>foo.ftl</result>

</action>

</package>

<package name="secure" namespace="/secure" extends="default">

<action name="bar" class="bar">

<result>bar.ftl</result>

</action>

</package>

</xwork>

这里,你的SpringapplicationContext.xml中有一个名为“bar”的bean。注意com.acme.Foo这个action不需要修改属性,它会自动autowire的。

记住:这不是必须的。这只在这种情况才必须,你希望覆盖掉已经在Webwork中创建的action,并且需要通过Spring支持但不能自动实决定的拦截器和IoC来装饰它的时候。记住,WebworkSpring继承只是标准的IoC,使用你指定的任何auto-wiring,甚至即使你没有显示的在Spring中映射action。所以一般来说你不需要这样做,但是如果需要的时候你最好知道这是如何实现的。

这段说的不太清楚,可能我翻译的不好。但是我理解它的意思是,可以不用修改class的名字,因为不修改它也会自动应用SpringAOP和其它IoC功能,当然是根据auto-wire的匹配。但是如果需要特别的确定要从Spring中装饰后再使用这个action,那么可以把class的属性修改掉。

倾听的优雅

Free是一种优雅。
如何Free?要做到的太多了,大家都在搜索。倾听能够让你心灵Free的修炼,类似一种禅。
引用如下:
倾听才能观察,实际观察你的心,它正在面对存在这个非常复杂的问题。不要去解释,以去解释你就不能倾听。倾听是一种专注的行动,在其中没有解释、没有比较——记得你读过的东西,而且和正再说的事比较,或和你自己的经验比较。那些都是分心。没有反抗的倾听,不要试着去寻找出答案,因为答案并不能解决问题。真正能完全解决问题的是,能够在没有意思到观察者的情形下观察,只要观察就可以了,而观察着只是过去的经验、记忆和知识。
本段话引用自 克里希那穆提的《爱与寂寞》二十一章“人类能否超越哀伤”。

心灵Free之路

《心灵Free之路》是一个老印的一本书,他被称作卓越的心灵导师。
这本书5块。
买它是因为我买了他的另一本《爱与寂寞》,书都是谈话式的,是开导人的,或者说心灵指引,不过说白了是一种对话式的生活哲学,而且深度不深,里面有点印度人的禅的感觉。
为什么看呢?因为我追求一种自我满足,在睡觉前眼睛快要睁不开的时候用这种书来折磨我的精神,哈哈,说笑。其实这本书翻译的一般,里面的很多说法算不上精妙,感觉是想到哪里说道哪里的流水帐,主题并不突出,而且章节非常多。这倒是适合我,每晚看一章节,4、5页而已,做梦的时候也许我会捉摸一下他讲过的问题。
当然“爱与寂寞”本身是因为我对爱和寂寞这个主题感兴趣,这里不展开,不过干想已经很有意思了,大家自己站看,有时间写个专题Blog。
其实对于这位克里希·穆·纳提来说,他的主题其实一直围绕Free这个问题,包括在爱与寂寞中他也多次探讨了。他总是把自己放在对思想自由和对人们的传教的这对矛盾中。
因为,思想要绝对的Free就没法传教,因为绝对的Free就是相当于没有导体的状态,但绝对的自由又应该是完全超导的状态,所以绝对的Free是没法存在的。所以他多次说(靠,我也这么说)自由是与恐惧共存的,爱也是与恐惧共存的。而且,这个观点很有意思,自由与我本身是对矛盾,要想绝对的自由就不能有我。而人的思想就是一种“我”,有了我就有了各种恐惧和对自己的各种束缚,所以就没法Free。
但是,这种想法,或者说人对自己的思想的本质问题的探讨就是不Free的表现。
这是个哲学范畴的问题。但是我是个没有那么高追求的人,我不愿意把这种简单的思想用哲学来形容,我只想简单的生活,但是要追求Free。
看这种书我马上有了自信,因为我感觉原来卓越的心灵导师的论述其实完全自然的存在于我幼小的心灵中,这种感觉让我满足,所以我也就愿意花时间看这种书,而且居然可以一目十行。
呼应我N久前写过的一篇文章,我们要进入我们的Free王国。如何进入我们的Free王国呢?看不到别人的夸奖,不在乎人家的批评,但自己要和自己对话,了解自己所想,判断自己所做,控制自己的情绪,接受别人的情绪,理解别人的思想,这样可以接近Free,因为绝对的Free是不存在的。
所以,用压缩饼干的方法说,上面的一大堆可以总结为:Free=接受+理解+控制=知足
本文不严谨指出请大家谅解,不欢迎拍砖,谢谢合作

上班写Blog是一件很悠闲的事情

一个多月前,那个晚上,我写了一个Blog阐述我忐忑的心情,不知人生向什么方向发展了,同时对马上要工作有一种紧张感。
而后就是进入公司开始干活,发现原来挣钱也不是那么难。
而后就是十一去了沈阳-丹东-东港-本溪,吃了很多好吃的,还游览了不少没去过的地方。给我留下最重要印象的是,我的GF和我在一起真的很快乐,即使在满是乘客的火车上,一个眼神也能给我无比的温暖,这样的旅行虽然说不上丰富多彩,但是却依然经常在梦中重温。
十一回来后的工作就变得越发的繁杂,在公司也基本上熟了,每天喝水上厕所,还有干手底下的活。还好有朋友罩着,没有什么不舒服的,但是比起上学的随心所欲,这样的生活有点机械,我不喜欢,因为我喜欢每天上进。也就是那个谁谁谁说的,每天写Blog的时候会发现收获。
而后,在我们自己的Conflunce上面的打拼也基本上停止了,因为生活变得忙碌,主要是上半之前的一个小时和下班之后的数个小时的时间都非常零散,很难有效率用,所以没有时间看帖子,没有时间学习,没有时间看电影。还好,吃饭和给GF打电话的时间还是有的,否则这种生活就真的不快乐了。
而后,在公司,慢慢的活变多起来了,我也就忙起来了。当我终于接触到公司程序源码的时候,还是吃了一惊,因为使用的框架都很全面,可惜代码非常丑陋,很多地方完全就是反模式,为了麻烦而麻烦,真是想不通。把Struts+Hibernate用成这个样子真是难以理解。还好技术主管让我用自己的技术,只要快就可以。我就偷懒使用了大量JSP+Scriptlet,还好,虽然是去年在用的技术,现在用起来依然很顺手。
其实,最近忙活的事很多。山东有个朋友开网吧,我在北京这边寻价格、找人、定配置,虽然这都是我的老强项了,可是被夹在中间再受资金限制,这些事情运作起来就不那么顺滑了,凭空耗费了大量精力去解除两边的冲突。今天一个朋友评价山东这位朋友“该清楚的地方弄神秘,该通过诚信关系的地方却较真”,弄得我很不好做人。还好,忙活过这几天就好了。
同时,这周发生的最震撼的事情就是,我辞职了。虽然是意料之中,但是还有点留恋,这里离我家很近,可以方便在我爸妈身边,这样很快乐。可是公司改在9:30-18:00的作息时间我不习惯(当然这个并不是主要原因),再说下面的工作要去,这边的工作就要辞。虽然是男孩,但是也应该有点男人的魄力,很顺畅的辞职了。
我的爸爸妈妈对我很支持,他们说只要我快乐,随便我怎样他们都支持我。只是我要离开他们身边一段时间,谁都有点不舍。
GF的爸爸听到我辞职感觉很诧异,感叹现在的年轻人……,哎,我没觉得怎样,没钱怎么生活,如果现在的工作阻碍了我的发展,那么我就应该果断地选择离开,没什么留恋的。工作可以勤换,家人却不会变,他们的爱也不会变!所以换换工作又怎样。
想到上周开始在BJUG的Groups里面跟贴,虽然最近作的技术实践很少,但是眼睛还是盯着技术的发展的,我准备认真的学习一下Webwork,还有Javascript和Ajax,离开这里以后还要继续看。本来在公司一开始每天还有时间学习的,后来忙起来就不行了,我计算了一下,其实是可以的,只要利用好这些时间。
还有,感慨一下,每周在北京拥堵的交通上耗费的时间真多呀,总要赶很远的路去看GF,每次都要赶公车真是很苦,希望以后有个直达的什么什么车。现在花了第一个月工资的两倍办了张浩沙会所健身卡,上周和GF去体验了一下,这样的生活感觉会健康一些。以后有时间很想过去,可是路这么远,再快的车也不是办法呀,所以,终极的解决方案就是结婚。
在这里偷偷和我家宝贝说一声:你愿意嫁给我么?你什么时候嫁给我?什么时候能够不要我受长长的孤单行程的困扰?
嗯,越说越多,我现在很会跑题呀,哈哈哈哈哈哈