公司是做erp软件的
以前用的是基于ejb2.0架构的,虽然从前(jsp、js)到后(ejb,crud)都有良好的接口,但做一个逻辑操作仍然很复杂。 又平时兴趣积累做出些东东,尝试着去应用到实际开发中去。总结了下这样的东东应该是这样的
1.尽量少的java scriptlet,尽量少的javascript,尽量少的硬sql(既跟着需求常变的)在java源码中
2.常用的逻辑操作流程定义明确,比如crud的开发,应该是step1->step2->step3...
3.基于一个灵活的架构,一些常用的功能尽量提供好,比如i18n,log,transactions,configurable,exception control,auth related等等
4.多定义,少编程。重复性的业务流程尽量模块化,最好达到修改或添加***时候能够改改配置就完成了
5.良好的命名合适和文件目录结构
因为好多操作都是crud操作,故我尝试着以以下方案解决上述问题——=》
1.选个好框架jquery/zk + freemarker + spring mvc + crud data server/dao + spring jdbc template + hibernate dialect,其中的crud的数据抽象和流程(page -> action -> service -> dao)自己要做的。
2.尽量多定义好目录结构 java源文件等就不说了,包命名,类命名,我喜欢springside风格的
war目录 crud crud的html相关文件(js,images,css,。。。 frame frame的html。。。 error pages 404/500。。。
web-inf目录
classes lib tld ftl zul config i18n model(这个是我定义的用于对数据库的数据抽象描述的,类似于**mapping)
spring config files * n web.xml
3. 额外的***
i18n我没用spring带的,我自己写一个interceptor加个cache功能,唯一比spring的多一点就是递归遍历文件夹,根据locale和业务相关(prefix)动态加载。这样i18n里的文件应该是这样的 i18n/pur/cn_account.properties
所谓配置,和i18n一样,只不过在interceptor的prehandle里也加载了,这样在action里面就不用出现汉字了,可能没这个必要。。。。
3. 权限相关 filter 做 url 访问判断,可以定义到db里去,**rbac,来个视图就搞定了
model filter 判断,至于model是什么,下面有讲
4. model???
先主要列几个java文件
CrudAction CrudService CrudDAO CrudModel SQLGenerator Dialect ValueFomatter,这下你大概知道偶想做什么了吧,还不明白?那就多列几个
XmlConvertable Field Row TableHeader TableLayer PaginationWrapper OptModel ConstraintModel,这下你大概知道偶想做什么了吧,还不明白?
那我也没办法了,那我就把Field.java放到附件里,感兴趣的看下吧
5.流程 其实呢,简单点理解,这个东东能做什么呢?它主要能做两方面的事情
pluginable功能组织结构通过定义展示给用户 比如用户 kerry 通过权限判断,他可以操作(pur模块下的***,srm下面的***),当然页面和数据你自己定义,象我预设的就是user usergroup role application-module resource这么几层,之间为多多对应
自动crud流程,通过4你应该猜到了一下
js+freemarker by ajax/get/post
crudaction(spring mvc annotation多好用啊)
listAll
listByQuery
listInPage
addForm/addPost
updateForm/updatePost
delete
addBatch/addBatchPost
deleteBatch
importFromExcel/exportToExcel ...
当然了,对httprequest的模块化操作,肯定要封装下了。
在action里,从user(request)里得到的是model, 对model的操作呢?外加点权限的 判断,比如这个model(对应一个视图、表或者**)是否可以导出啊,是否可以删除啊 等等。
crudservice 这一层和action其实几乎是一一对应的,只不过声明了事务处理啊,判断下key constraint啊,对model的**(比如视图的view sql)根据登录user进行下转换啊什么 的——sql转换我深有感触,处处都有啊(比如一个插入,出来key constraint以外, 说不定还有业务上的constraint,这些动态sql都要转换的)
cruddao 这一层比较bug,不过操作起来逻辑上很清晰,无非是crud,至于sql怎么生成的,jdbc template用到的object[]是如何生成的,交给别的类吧
6.说了这么多,关键的一点就是,不要以为上面的代码都要自己去写,no——我按照这个思路做出来个雏形暂时可以达到根据几个xml就可以做action里定义的所有方法了
如果你要问,咦?那页面哪有啊——自动生成啊,反正你把数据库表的每个字段都映射定义了,生成个table/form还有问题啊,切,包括js验证都有了——顺便白一句,我估计,我自己定义的field的属性,应该比jpa的annotation定义的都多…………不过带来的是xml维护的地狱,幸好偶命名的规范些,要不然,一个系统就这几百个xml文件,一行java没有,你上哪去搞去啊
今天晚了,改天看看要不要再写点。 大家来拍砖啊,提点建议最好——毕竟偶是闭门造车啊