`
yale
  • 浏览: 356930 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

ssh2(struts2+spring2.5+hibernate3.3)自动代码生成器程序

阅读更多

为什么需要自动生成代码?

作为一个软件公司,开发团队非常重要,作为一个开发团队,人员配备、开发效率等都非常重要,但是开发效率包含很多,如:代码质量(扩展性、重构性等),但是这些都是建立在规范的代码之上来进行,在一个团队中,每个开发者都有自己的习惯方式来进行代码的编写,例如(ssh文件名举例):

dao接口:  写法一:IXXXDao,  写法二:IXXXDAO 等等

dao实现类: 写法一:XXXHibernateDAO,写法二:XXXHibernateDao,写法三:XXXDAO等等

service接口:写法一:IXXXService,写法二:IXXXManager等等

service实现: 写法一:XXXServiceImpl,写法二:XXXService,写法三:XXXManagerImpl等等

action: 写法一:XXXAction XXXManager等等

还有配置文件的一些注入,以及命名,会有很多种,可能这时会有很多人认为只要function体里面的代码逻辑质量高,很规范的运用了面向对象的思想,对逻辑封装的好,性能高,这些规范不规范的有什么问题,影响不了程序的性能,如果你是这样想的,那么我会对你说,你成不了气候,永远都是一个边缘的开发者, 打个比方:一个公司如果没有良好的规章制度,你觉得这个公司好吗? 同样的道理,一个好的项目,没有自己的一套编码规范,是个好的项目吗?

就算在项目开发前定制了规范,也有开发人员因为自己的习惯忘记了定制的规范,按照自己的风格来进行代码编写,这样久而久之,一个项目中各种风格的代码都有,对于ssh架构的开发人员每天都会遇到重复的代码编写(当然对重复的代码有可能你会ctrl+c,ctrl+,就算是ctrl+c,ctrl+v也需要花大量的时间做些无意义的代码编写,这样降低了开发效率,同时好多开发人员对ssh也产生了抵触,认为自己一天到晚都在写些没有用的代码,自己感到很沮丧!

 

本程序的来源

 

jsmart

  在网上search了这样的插件,以及相关的源码,对jsmart映象比较深,试用该插件后发现功能虽然强大(能够生成各种框架的环境搭建,以及fck等编辑器的初始化),但是发现有很多的规则受限制:

1.每次自动生成的代码都是一次性全部初始化生成,对于二次开发的人员来讲,需要对自己想要指定的单表(数据库表)进行生成(bean,hbm.xml,dao.service,action)时,该插件无法做到,我想了一下,作者应该会考虑到这一点吧,因此询问该作者后,他说要购买企业版,能够达到该功能

2.定制了自己的数据库规范, 该插件对数据库表进行了限制,如:数据库表名不能带有_(下划线),字段名也不能带有,这点我是最受不了的,不想多说了,从这点,我也就没有继续往下试了.

 

rapid-framework

 经过再三的筛选,最后选择了一个开源的框架rapid-framework,如果想要进行全新开发一个项目,又想快速的初始化项目,那么rapid-framework

 

因为本人仅限于生成自己定制的模版文件,然后自动生成,并非想自动生成整个项目,所以对该项目的部分代码进行了解读,并对需要使用的类提取到自己的项目中,然后对自己需要的定制作了相应的修改,完成了一个自动生成的程序.

 

生成代码后的目录结构如下:

com.bestsoft.ssh目录下的

 bean/{自定义的存放包}目录: bean文件、hbm.xml文件

 dao/{自定义的存放包}目录:接口类

 dao/hibernate/{自定义的存放包}目录:实现类

 service/{自定义的存放包}目录:接口类

service/impl/{自定义的存放包}目录:实现类

action/{自定义的存放包}目录:struts2的类

 

conf目录下的

{自定义的存放包}目录:4个xml文件(applicationContext-dao.xml(dao注入配置),applicationContext-service.xml(service注入配置),action-servlet.xml(action注入配置),struts-{自定义的存放包名}.xml(struts2的action配置文件))

 

以上是根据我自己项目目录以及代码需要自动生成哪些内容而自己定制的,包括类中的方法等自己都可以定制.

  

实现技巧:

generator\template\src\conf\${subpackage}下的文件实现:

generator\template\src\conf\${subpackage}\目录下有8个xml文件,4个配置文件中是带有xml文件头信息的,4个配置文件不带头文件信息,也就是说这4个文件是标准的配置文件,还有4个是非标准的(文件名中带有-insert的)。

配置文件的作用:

标准的配置文件是在第一次生成代码的时候调用,来生成一个完整的配置文件的内容,如果说想在此配置文件的内容中增加内容,怎么办?

大家可以看到,标准的4个配置文件中都带有“<!-- webapp-generator-insert-location -->”这样的注释,该注释的主要作用是用来在该配置文件原有内容的基础上增加新的内容,但是这个新增加的内容从哪里来? 这些内容就是从带"-insert"的配置文件中来,把带"-insert"的配置文件内容加入到不带“insert”的配置文件中去。

generator\template\src\${basepackage_dir}目录下的文件实现:

generator\template\src\${basepackage_dir}\bean 该目录下文件定制bean,以及or/map文件的模板

generator\template\src\${basepackage_dir}\dao 该目录下文件定制dao文件的模板

generator\template\src\${basepackage_dir}\service 该目录下文件定制service文件的模板

generator\template\src\${basepackage_dir}\web\action\${subpackage} 该目录下文件定制action文件的模板。

上述文件模板中的内容可以根据自己的需求来作相应功能的增加,修改等

 

generator\src目录下的文件实现:

generator.properties文件:配置信息,大家可以看到我们的目录或者模板文件中含有${}的符号,这些${}的内容就是在这里进行配置的.

 

GeneratorMain.java(该类用来传入一个参数:"表名(数据库表)",然后就会生成想要生成的模版),Generator.java(该类实现想要定制哪些模版文件来进行生成,生成后的文件存放在哪里),generator.properties(配置自己的数据库信息,存放包的信息等),template目下的所有文件(该目录下存放的是模版文件,用来只自定义自己想要生成类,xml文件的模版内容)。

红色部分中的类可能是你要进行修改的类,其他包的类大家一看就知道是做什么用的.

 

附件是该程序的代码,该程序只是一个demo,提供了解决该问题的方法,每个项目定制自动生成代码的内容都不一样,但是只需要在该demo的基础上做相应的修改,就可以实现自己想要的内容,  如果还有不清楚的地方,可以留言给我,我会针对留言来进行回复,因为该demo只对ssh2做了程序自动生成,如果该demo无法满足你更多的需要,可以在网上搜索rapid-framework框架,来进行更多框架的代码自动生成.

 

  • jar.rar (1.5 MB)
  • 下载次数: 2446
56
9
分享到:
评论
17 楼 LinApex 2014-07-06  
完全没有任何作用,对于真正有实力的团队来说,这点小东西是远远不够的,代码生成会根据公司业务来调整
16 楼 llscp 2013-05-14  
麻烦问一下 基于实体生成的例子有没有......我邮箱
1732947086@qq.com
谢谢......
15 楼 manhao1987 2012-09-27  
oracele 配置的时候 jdbc.schema jdbc.catalog 这2个要怎么配置,坐等答复
14 楼 zhengdi 2012-03-14  
楼主的东西好
13 楼 badqiu 2009-09-10  
solonote 写道
无意义的工具,既然能够生成这样的代码,就是存在着相同的东西,对于这种东西你推行的是Copy代码(生成就是这个道理),而完全可以用抽象的方式,把这些东西抽象出来,很简单就能达到你的目的.
而且每一个Entity必须要有一个IDAO?必须要有一个DAO?必须要有一个IService?必须要有一个Service?
这种设计是如此的丑陋,但是居然还有无数人很喜欢喝尊崇这样丑陋的设计


可以查看下rapid-framework,生成的代码将是即其精简。避免如你所述问题。

http://code.google.com/p/rapid-framework/downloads/list
12 楼 solonote 2009-09-10  
无意义的工具,既然能够生成这样的代码,就是存在着相同的东西,对于这种东西你推行的是Copy代码(生成就是这个道理),而完全可以用抽象的方式,把这些东西抽象出来,很简单就能达到你的目的.
而且每一个Entity必须要有一个IDAO?必须要有一个DAO?必须要有一个IService?必须要有一个Service?
这种设计是如此的丑陋,但是居然还有无数人很喜欢喝尊崇这样丑陋的设计
11 楼 ChinaEstone 2009-09-09  
同志们以后没饭吃了
10 楼 ray_java 2009-09-09  

好的,借鉴下,谢谢!!
9 楼 風一樣的男子 2009-09-08  
一直在寻找好用的代码生成工具
下载了,有时间研究下
8 楼 超级潜水员 2009-09-08  
楼主的生成器不错,但是该模板生成的代码过多,建议使用范型等来精简模板代码.
7 楼 uniquejava 2009-09-08  
very good  谢谢分享:idea:
6 楼 mccxj 2009-09-08  
生成器初期还有点用。。就像rails的sacffold
约定是比较有效的。。看rails的coc就知道了
自动生成代码--对这样的标题不感冒。。
5 楼 超级潜水员 2009-09-07  
生成器不错!!
4 楼 swen00 2009-09-07  
约定编程是可以提高效率,支持下
3 楼 xiaohai_110 2009-09-07  
大哥,那个公司的?武汉人?能交个朋友么?
2 楼 xiaohai_110 2009-09-07  
强,要好好的学习下了。
1 楼 zkl_1987 2009-09-07  

相关推荐

Global site tag (gtag.js) - Google Analytics