流程设计好了以后,我们要持久化到数据库中,我们用的是Mysql,jbpm3.2版本数据库文件是有问题的,不过jbpm4.4修复了这个问题。

一、准备数据库

  • 1.1首先安装ant   >>>>  baidu  or google
  • 1.2修改jbpm4.4的mysql.properties,主要是创建数据库的时候能对应你在mysql里面建立的schema,因为jbpm默认是用hibernate实现数据库的持久化 >>>>>D:\jbpm-4.4\install\jdbc
  • 1.3    cmd到>>>>>D:\jbpm-4.4\install 运行ant -Ddatabase=mysql create.jbpm.schema
    当看到 Successful字样的时候,去数据库检查一下看看表是否都建好了

二、创建Project

  • 2.1首先要创建一个Dynamic Web Project项目,并将jbpm配置文件放在指定位置,最后引入D:\jbpm-4.4\lib 下的jar
  • 我的jbpm.hibernate.cfg.xml
     
        
    1. <?xml version="1.0" encoding="utf-8"?> 
    2.  
    3. <!DOCTYPE hibernate-configuration PUBLIC  
    4.           "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  
    5.           "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> 
    6. <hibernate-configuration> 
    7.   <session-factory> 
    8.      <property name="hibernate.dialect">org.hibernate.dialect.MySQLInnoDBDialect</property> 
    9.      <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> 
    10.      <property name="hibernate.connection.url">jdbc:mysql://192.168.0.100:3307/mtf_jbpm</property> 
    11.      <property name="hibernate.connection.username">MTF</property> 
    12.      <property name="hibernate.connection.password">a123b456</property> 
    13.      <property name="hibernate.hbm2ddl.auto">update</property>  
    14.  
    15.     <!--  <property name="show_sql">false</property> 
    16.     <property name="hibernate.format_sql">true</property> --> 
    17.  
    18.      <mapping resource="jbpm.repository.hbm.xml" /> 
    19.      <mapping resource="jbpm.execution.hbm.xml" /> 
    20.      <mapping resource="jbpm.history.hbm.xml" /> 
    21.      <mapping resource="jbpm.task.hbm.xml" /> 
    22.      <mapping resource="jbpm.identity.hbm.xml" />   
    23.  
    24.   </session-factory> 
    25. </hibernate-configuration> 

    需要注意的是hibernate.hbm2ddl.auto create-drop是默认,有点遗忘……

  • 2.3引入jbpm的jar >>D:\jbpm-4.4\lib 下,注意包的冲突,不要引入重复的
  • 1.   ${JBPM_HOME}/jbpm.jar(核心包)

    2.   JBPM_HOME/lib/*.jar,不添加以下jar包:servlet-api.jar, junit.jar。其中junit.jar一定不要添加,因为是3.8.2版本,与我们使用的junit4有冲突。

    3.   所使用的数据库对应的驱动的jar包(第2步所添加的jar包中已包含mysqljdbc驱动jar包)。

三、部署流程到Mysql数据库

  • 3.1需要写一个Junit testCase
     
        
    1. public class LeaveDeploy {  
    2.     private String deploymentId;  
    3.     private ProcessEngine processEngine;  
    4.     private TaskService taskService;  
    5.     private RepositoryService repositoryService;  
    6.     private ExecutionService executionService;  
    7.     private HistoryService historyService;  
    8.     @Test 
    9.     public void testDeploy() {  
    10.         processEngine = new Configuration().getProcessEngine();  
    11.         repositoryService = processEngine.getRepositoryService();  
    12.         executionService = processEngine.getExecutionService();  
    13.         taskService = processEngine.getTaskService();  
    14.         historyService = processEngine.getHistoryService();  
    15.         deploymentId = processEngine.getRepositoryService().createDeployment()  
    16.                 .addResourceFromClasspath("com/mtf/jbpm/process/leaveProcess.jpdl.xml")  
    17.                 //指定jpdl.xml的路径  
    18.             //  .addResourceFromClasspath("test/leaveProcess.png")  
    19.                 .deploy();  
    20.         System.out.println("发布成功!");  
    21.         System.out.println(deploymentId);  
    22.     }         

    运行junit,成功后发现数据库中有相应的记录就成功啦,其间可能遇到运行成功但是数据库没有字段增加的情况,忘了怎么解决了,我记的是粗心大意所致
     

四、总结

        这部分其实是很简单的,我刚开始用jbpm4.4的时候就是持久化不了数据库,记忆中好像是因为哪个地方配置出错了……还有就是我写的项目其实很偷懒,jbpm实际上要求我们管理流程定义(增删改查),部署流程实际上推荐我们打成zip包上传到服务端然后在持久化到数据库,但是我觉得这样简单嘛,能用就行啦……