作者:
序
人人都爱spring加hibernate。
但spring mvc hibernate的sample如appfuse的代码却算不得最简洁优美好读,如果在自己的项目中继续发挥我们最擅长的依样画葫芦大法,美好愿望未必会实现。
所以,pramatic精神不灭。这个系列就是探寻最适合自己的spring hibernate模式。
i-配置文件简化
我厌倦一切配置文件繁重的框架。
最好的情况是,框架提供极端灵活复杂的配置方式,但只在你需要的时候。
spring提供了三种可能来简化xml。随着国内用户水平的提高,这些基本的简化技巧大家都已掌握。
大家可以直接看第3,第4点--spring 1.2, spring 2.0的后继改进。
1.1.autowire="byname" /"bytype"
假设controller有一个属性名为customerdao,spring就会在配置文件里查找有没有名字为customerdao的bean, 自动为controller注入。
如果bean有两个属性,一个想默认注入,一个想自定义,只要设定了autowire,然后显式的声明那个想自定义的,就可以达到要求。这就应了需求,在需要特别配置的时候就提供配置,否则给我一个默认注入。
还有一个更懒的地方,在最最根部的节点写一句default-autovwrie="byname",可以让文件里的所有bean 都默认autowrie。
不过rod认为开发期可以这样,但production server上不应该使用autowire。而我觉得那些自定义一次的地方比如transcationmanager应该详细定义,而dao,controller这种大量重复定义的bean就可以偷点懒了。
1.2.节点之间抽象公共定义和 inner bean
这太方便懒人了,想不到两个独立的xml节点都可以玩继承和派生,子节点拥有父节点的全部属性。
最好用的地方就是那个transtion proxy的定义。先定义一个又长又冗的父类,然后用子类去继承它。
另外,还有一个inner bean的机制,可以把dao写成proxy的内部类。为什么要写成内部类?为了让proxy冒名顶替它去让controller autowire。(详见后面的示例)
1.3. 宽松的配置, to xml or not to xml
据说spring比struts的配置宽松了很多,这就给人把东西从配置文件中撤回原码中的机会。
不赞成什么都往配置文件里晒,造成了rich information的配置文件,修改或者查看的时候,要同时打开配置文件和原码才能清楚一切。
而我希望配置文件就集中做一些整体的配置,还有框架必须的、无需管理的冗余代码。而一些细节的变化不大的配置和逻辑,就尽量别往里塞了。因此,success/fail view 的配置,不建议放在里面。
2.简化后的配置文件
1.controller只剩下一句
<bean name="customercontroller" class="org.springside.bookstore.web.customercontroller" autowire="byname"/>
2.dao也只剩一句
<bean id="customerdao" class="org.springside.bookstore.dao.customerdao"/>
3.service类只剩下5行
<bean id="customermanager" parent="basetxservice">
<property name="target">
<bean class="org.springside.bookstore.service.customermanager"/>
property>
bean>
3.spring 1.2后xml语法简化
最主要的简化是把属性值和引用bean从子节点变回了属性值,对不喜欢autowire的兄弟比较有用。
当然,如果value要cdata的时候还是要用子节点。另外,list的值可以用空格隔开也比较实用。
<property name="myfriendlist">
<list>
<value>gigixvalue>
<value>wuyuvalue>
list>
property>
简化为
<property name="myfriendlist" value="gigix wuyu"/>
4.spring 2.0来了 如果没什么外力刺激,spring xml 可能就这样不会变了。但现在xml成了过街老鼠,被ror的默认配置和jdk5的annotation逼得不行,当然就要继续求变。
比如有好事者认为,节点名必须以bean打头,附加一个属性id来表示bean名;属性值必须搞一个property子节点,子节点上有个属性name来表示属性名,是给机器看的很不直观的东西。
<bean id="customerdao" class="org.springside...customerdao">
<property name="maxcount" value="10">
bean>
给人看的东西应该就写成
<customerdao class="org.springside....customerdao" maxcount="10"/>
spring 2.0正用schema实现类似的语法,具体请看它的jpetstore sample。
5.使用spring自带的dtd使编辑器smart.
如果没有用eclipse的spring插件,那至少也要使用spring自带的dtd使xml编辑器smart一些,能够自动为你生成属性,判断节点/属性名称有没有拼错等。
6.还有更变态的简化配置方法
比如autoproxy,不过我觉得更简化就不可控了,所以没有采用。
相关文章
简化spring(1)--配置文件