好文:

偶然机会,认识了工作流系统,并且在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到。这里就不给地址了。自己动手找找吧。

JBMP学习引导-LMLPHP

好了,如果你对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,今天到此为止,需要休息了,JBMP学习引导-LMLPHP明天续。。。

=====================================

好文2:

http://rmn190.iteye.com/blog/792731

http://www.blogjava.net/chengang/archive/2006/07/13/57986.html

05-12 21:42