偶然机会,认识了工作流系统,并且在www.open-open.com(相当不错的开源项目站点,极力推荐!)上了解了些相当出色的工作流系统,不过呼声最高的应该属JBoss 的JBPM工作流组件了。
正好有个项目需要用到工作流机制,遂学习了下JBPM,感受了下JBPM带来的的便捷体验。现在我就把我的学习经历记录下来。和大家共同分享,也希望对那些刚研究JBPM的同仁们有所帮助。
ok,那就开始吧!
一。对于没有接触过JBPM的,可以先了解下JBPM应用场合,和JBPM的相关概念。我想如下这些东西将对你的JBPM学习很有帮助。
1。JBPM开发指南.pdf---------http://dl2.csdn.net/fd.php?i=12492886032537&s=020d83ba442aba86919657b97e51a699----对JBPM中的配置进行了比较详细的阐述。
2。还有就是大师级人物--陈刚 的教程http://www.blogjava.net/chengang/archive/2006/07/13/57986.html
,不过,这个教程只是简单的介绍了下JBPM的使用。对于初次接触JBPM的学习者来说,是个很好的选择。它将让你对JBPM有个较清晰的认识。
3。还有就是传智播客的一套关于JBPM的视频,verycd上就可以search到。这里就不给地址了。自己动手找找吧。
好了,如果你对JBPM有些认识了,那就开始来做个Struts+Hibernate+Spring+JBPM的文章审批系统吧。
首先介绍下该系统具体做些什么吧!
用户在该系统中发表文章,然后请求发布,该文章需要经过层层审批,再确定是否能发布。就像一个出版社中,当要出版一篇文章,需要经过 一级审批,二级审批,三级审批.......最终确定发表该文章。需要说明的是,为了体现JBPM对流程的适配的特性,我们做的系统会定义4个不同的流程来展示JBPM的这一特性。对于不同的流程,系统会自动按照不同的流程定义文件来执行。
准备工作:
该系统的数据库环境为MySQL,如果要在其他数据库上完成也很简单,只需要在目标数据库建立起JBPM的表结构和业务表就可以,这里,就可以参考前面陈刚老师的教程了。就不再赘述了(如果需要可到附件中获得)。业务表建表语句如下:
/*==============================================================*/
/* Table: Article */
/*==============================================================*/
create table Article
(
ArticleNo int AUTO_INCREMENT not null comment '文章号',
UserNo int comment '用户号',
TypeNo int comment '文章类型号',
ArticleName varchar(128) comment '文章名称',
Content text comment '文章内容',
PiId bigint comment '对应流程实例号',
AuditState varchar(64) comment '审批状态',
AuditComment varchar(255) comment '审批说明',
State int comment '文章状态',
primary key (ArticleNo)
);
alter table Article comment '文章表';
/*==============================================================*/
/* Table: ArticleType */
/*==============================================================*/
create table ArticleType
(
TypeNo int AUTO_INCREMENT not null comment '文章类型号',
PdName varchar(255) comment '流程名称',
TypeName varchar(40) comment '类型名称',
primary key (TypeNo)
);
alter table ArticleType comment '文章类型表';
/*==============================================================*/
/* Table: User */
/*==============================================================*/
create table User
(
UserNo int AUTO_INCREMENT not null comment '用户号',
DutyNo int comment '职责号',
LoginName varchar(50) not null comment '账号',
Password varchar(32) comment '密码',
UserName varchar(50) comment '姓名',
primary key (UserNo)
);
alter table User comment '用户表';
/*==============================================================*/
/* Table: UserDuty */
/*==============================================================*/
create table UserDuty
(
DutyNo int AUTO_INCREMENT not null comment '职责号',
Name varchar(255) comment '名称',
DutyType varchar(20) comment '职责类型',
DutyValue varchar(64) comment '职责值',
primary key (DutyNo)
);
alter table UserDuty comment '用户职责表';
alter table Article add constraint FK_Relationship_1 foreign key (TypeNo)
references ArticleType (TypeNo) on delete restrict on update restrict;
alter table Article add constraint FK_Relationship_2 foreign key (UserNo)
references User (UserNo) on delete restrict on update restrict;
alter table User add constraint FK_Relationship_3 foreign key (DutyNo)
references UserDuty (DutyNo) on delete restrict on update restrict;
insert into `userduty`(`DutyNo`,`Name`,`DutyType`,`DutyValue`)
values (1,'管理员','管理员','管理员');
insert into `userduty`(`DutyNo`,`Name`,`DutyType`,`DutyValue`)
values (2,'普通用户','普通用户','普通用户');
insert into `userduty`(`DutyNo`,`Name`,`DutyType`,`DutyValue`)
values (3,'一级审批员','审批员','一级审批');
insert into `userduty`(`DutyNo`,`Name`,`DutyType`,`DutyValue`)
values (4,'二级审批员','审批员','二级审批');
insert into `userduty`(`DutyNo`,`Name`,`DutyType`,`DutyValue`)
values (5,'三级审批员','审批员','三级审批');
insert into `userduty`(`DutyNo`,`Name`,`DutyType`,`DutyValue`)
values (6,'四级审批员','审批员','四级审批');
insert into `user`(`UserNo`,`DutyNo`,`LoginName`,`Password`,`UserName`)
values (1,1,'manager','manager','管理员');
insert into `user`(`UserNo`,`DutyNo`,`LoginName`,`Password`,`UserName`)
values (2,2,'guest','guest','普通用户');
insert into `user`(`UserNo`,`DutyNo`,`LoginName`,`Password`,`UserName`)
values (3,3,'one','one','一级审批员');
insert into `user`(`UserNo`,`DutyNo`,`LoginName`,`Password`,`UserName`)
values (4,4,'two','two','二级审批员');
insert into `user`(`UserNo`,`DutyNo`,`LoginName`,`Password`,`UserName`)
values (5,5,'three','three','三级审批员');
insert into `user`(`UserNo`,`DutyNo`,`LoginName`,`Password`,`UserName`)
values (6,6,'four','four','四级审批员');
(建表文件请附件下载)
OK,今天到此为止,需要休息了,明天续。。。
分享到:
相关推荐
完整工作流JBPM项目实战全过程教程---项目详细讲解.doc
NULL 博文链接:https://zpchen.iteye.com/blog/258252
这个是新定义的流程processDefinition.xml等文件打包的zip包 博文链接:https://zpchen.iteye.com/blog/259059
介绍工作流在java方面的应用,介绍工作流的开发流程
jbpm-jpdl-designer-site-3.1.7.zip jbpm-jpdl-designer-site-3.1.7.zip jbpm-jpdl-designer-site-3.1.7.zip
jbpm-jpdl-suite-3.2GA -(5)分开压缩(共5个文件)jbpm下载 jbpm-jpdl-suite-3.2GA -(5)分开压缩(共5个文件)jbpm下载
对JBPM工作流进行二次开发,主要包括对JBPM功能的扩展、流程定义工具、流程实例监控工具、工作流控制台、应用程序接口以及组织结构扩展接口的开发。 在次基础上,开发基于工作流系统的办公自动化系统等相应的业务...
工作流jbpm---学习文档+简单实例项目,里面有两个文档说明,一个ssh+jbpm项目实例
jbpm工作流教程,4.1版本的Java工作流
jbpm-jpdl-designer资源
jBPM工作流详解,jBPM工作流详解 jBPM工作流详解,jBPM工作流详解 jBPM工作流详解,jBPM工作流详解
JBPM5工作流引擎 S2SH+JBPM4.4开发工作流的一个完整的请假流程例子。带有文档教程和所有源码+JAR包。在网上找了半天jbpm6\jbpm7的资料,都很少。所以 环境:Myeclipse2015 JDK1.7 mysql 5.0 Struts2+Spring3.1 1...
jbpm-3_2_2-Api jbpm 著名工作流引擎
工作流程 JBPM工作流管理工作流程 JBPM工作流管理工作流程 JBPM工作流管理工作流程 JBPM工作流管理
JBPM工作流全套学习资料!比较全面的介绍了jbpm,可以作为学习工作流的参考资料.
jbpm-3.1.4.jar,jbpm工作流引擎jbpm工作流引擎