<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    paulwong

    jbpm4.3與spring集成

    jbpm4.2與spring集成有點(diǎn)問(wèn)題,直接跟據(jù)它自己的“開(kāi)發(fā)指南”提供的方法是不能集成的。在官網(wǎng)查到的信息是發(fā)布4.2時(shí),忘記更新集成spring的文件。不過(guò)4.3已經(jīng)把該bug改過(guò)來(lái)了。下面是集成方法。

    版本:
    jbpm4.3
    spring2.5.6
    mysql5.1.40

    直接從jbpm4.3自帶的文件到src目錄:
    從jbpm-4.3"install"src"cfg"hibernate"jdbc復(fù)制mysql.hibernate.cfg.xml到src目錄,文件名改為hibernate.cfg.xml。
    從jbpm-4.3"install"src"cfg"spring復(fù)制applicationContext.xml到src目錄。
    從jbpm-4.3"install"src"cfg"jbpm復(fù)制spring.jbpm.cfg.xml到src目錄,文件名改為jbpm.cfg.xml。
    修改applicationContext.xml、hibernate.cfg.xml的數(shù)據(jù)庫(kù)配置信息,jbpm4.3與spring的集成就完成了,可以自己寫(xiě)測(cè)試文件測(cè)試,集成非常容易。

    不過(guò)在applicationContext.xml和hibernate.cfg.xml兩個(gè)文件都要改數(shù)據(jù)庫(kù)信息有點(diǎn)麻煩,所以只復(fù)制applicationContext.xml、spring.jbpm.cfg.xml兩個(gè)文件到src目錄,把hibernate.cfg.xml的配置整進(jìn)spring的配置文件applicationContext.xml中。
    applicationContext.xml
    <beans xmlns="http://www.springframework.org/schema/beans" 
             xmlns:aop
    ="http://www.springframework.org/schema/aop" 
             xmlns:context
    ="http://www.springframework.org/schema/context"
              xmlns:p
    ="http://www.springframework.org/schema/p"
             xmlns:tx
    ="http://www.springframework.org/schema/tx"
           xmlns:xsi
    ="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation
    ="
              http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
              http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
              http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
              http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd"
    >
     
     
    <context:annotation-config />

    <bean
      
    class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"
      p:location
    ="hibernate.properties"
      p:ignoreUnresolvablePlaceholders
    ="true" />
      
    <bean id="springHelper" class="org.jbpm.pvm.internal.processengine.SpringHelper" />
      
    <bean id="processEngine" factory-bean="springHelper" factory-method="createProcessEngine" />
      
    <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        
    <property name="dataSource" ref="dataSource" />
        
    <property name="mappingResources">
            
    <list>
                
    <value>jbpm.repository.hbm.xml</value>
                
    <value>jbpm.execution.hbm.xml</value>
                
    <value>jbpm.history.hbm.xml</value>
                
    <value>jbpm.task.hbm.xml</value>
                
    <value>jbpm.identity.hbm.xml</value>
            
    </list>
        
    </property>
        
    <property name="hibernateProperties">
            
    <props>
                    
    <prop key="hibernate.dialect">${dataSource.dialect}</prop>
                    
    <prop key="hibernate.hbm2ddl.auto">${dataSource.hbm2ddl.auto}</prop>
                
    </props>
        
    </property>
      
    </bean>
      
    <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
        
    <property name="sessionFactory" ref="sessionFactory" />
        
    <property name="dataSource" ref="dataSource" />
      
    </bean>
      
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        
    <property name="driverClassName" value="${dataSource.driverClassName}" />
        
    <property name="url" value="${dataSource.url}" />
        
    <property name="username" value="${dataSource.username}" />
        
    <property name="password" value="${dataSource.password}" />
      
    </bean>
    </beans>


    新建文件hibernate.properties,主要用來(lái)配置連接數(shù)據(jù)庫(kù)信息

    dataSource.password=123
    dataSource.username
    =root
    dataSource.databaseName
    =jbpmdb
    dataSource.driverClassName
    =com.mysql.jdbc.Driver
    dataSource.dialect
    =org.hibernate.dialect.MySQLInnoDBDialect
    dataSource.serverName
    =localhost:3306
    dataSource.url
    =jdbc:mysql://${dataSource.serverName}/${dataSource.databaseName}
    dataSource.properties
    =user=${dataSource.username};databaseName=${dataSource.databaseName};serverName=${dataSource.serverName};password=${dataSource.password}
    dataSource.hbm2ddl.auto=update

    以后要改數(shù)據(jù)庫(kù)配置信息也只在這個(gè)文件修改就可以了。

    測(cè)試用的流程swing.jpdl.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <process name="swing" xmlns="http://jbpm.org/4.3/jpdl">
       
    <start g="94,64,48,48" name="start1">
          
    <transition g="-52,-22" name="A" to="A"/>
       
    </start>
       
    <task assignee="A" g="73,195,92,52" name="A">
          
    <transition g="-52,-22" name="B" to="B"/>
       
    </task>
       
    <task assignee="B" g="266,192,92,52" name="B">
          
    <transition g="-40,-21" name="end" to="end1"/>
       
    </task>
       
    <end g="290,327,48,48" name="end1"/>
    </process>


    測(cè)試代碼

    public class Main {
        
    public static void main(String[] args)  {
            ClassPathXmlApplicationContext applicationContext 
    = new ClassPathXmlApplicationContext("applicationContext.xml");
            applicationContext.start();
            ProcessEngine processEngine 
    = (ProcessEngine)applicationContext.getBean("processEngine");
            ExecutionService executionService 
    = processEngine.getExecutionService();
            TaskService taskService 
    = processEngine.getTaskService();

            
    //發(fā)布流程
            String deploymentId = processEngine.getRepositoryService().createDeployment()
            .addResourceFromClasspath(
    "resource/swing.jpdl.xml").deploy();
            System.out.println(
    "流程發(fā)布ID:"+deploymentId);
            
            
    //啟動(dòng)一個(gè)流程實(shí)例
            ProcessInstance processInstance = executionService.startProcessInstanceByKey("swing");
            System.out.println(
    "流程實(shí)例ID:" + processInstance.getId());

            
    //A處理任務(wù)
            List<Task> taskList_A = taskService.findPersonalTasks("A");
            System.out.println(
    "A待處理任務(wù)數(shù):" + taskList_A.size());
            
    if(taskList_A.size() > 0){
                Task task 
    = taskList_A.get(0);
                taskService.completeTask(task.getId());
            }

            
            
    //B處理任務(wù)
            List<Task> taskList_B = taskService.findPersonalTasks("B");
            System.out.println(
    "B待處理任務(wù)數(shù):" + taskList_B.size());
            
    if(taskList_B.size() > 0){
                Task task 
    = taskList_B.get(0);
                taskService.completeTask(task.getId());
            }

            
        }

    }


    附件是完整的集成文件和測(cè)試代碼,僅在spring2.5.6測(cè)試過(guò),要運(yùn)行該部分代碼,需要添加jbpm4.3和spring的相關(guān)庫(kù)文件。
    源代碼:jbpm4.3-spring

    posted on 2010-01-08 12:40 paulwong 閱讀(838) 評(píng)論(0)  編輯  收藏 所屬分類: JBPM

    主站蜘蛛池模板: 91嫩草国产在线观看免费| 一级毛片在线观看免费| 最近免费中文在线视频| 国产V亚洲V天堂A无码| 久久99久久成人免费播放| 免费日韩在线视频| 鲁啊鲁在线视频免费播放| 拔擦拔擦8x华人免费久久| 亚洲综合欧美色五月俺也去| 在线观看无码AV网站永久免费| 亚洲国产精品白丝在线观看| av无码国产在线看免费网站| 亚洲精品日韩专区silk| 100部毛片免费全部播放完整| 亚洲成人福利在线观看| 成人女人A级毛片免费软件| 2017亚洲男人天堂一| 在线播放高清国语自产拍免费| 亚洲色大18成人网站WWW在线播放 亚洲色大成WWW亚洲女子 | 一二三四免费观看在线电影 | 性色av无码免费一区二区三区| 亚洲成人免费网站| 免费无码AV片在线观看软件| 亚洲精品无码专区久久| 免费在线看片网站| 国产中文字幕在线免费观看| 亚洲大片在线观看| 野花高清在线观看免费完整版中文 | 成年女人免费碰碰视频| 日韩色视频一区二区三区亚洲 | 亚洲AV日韩AV无码污污网站| 免费人成无码大片在线观看| 一级做a爱过程免费视频高清| 国产精品亚洲аv无码播放| 亚洲成人免费网站| 亚洲风情亚Aⅴ在线发布| 午夜亚洲国产成人不卡在线| 中文字幕在线视频免费观看| 亚洲成av人片在线看片| 日韩免费a级在线观看| 丝瓜app免费下载网址进入ios|