Spring与JBPM整合

2024-01-13 05:58
文章标签 java spring 整合 jbpm

本文主要是介绍Spring与JBPM整合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

整合的先后顺序是关键,下面按照顺序一步一步来设置:


1.首先jbpm是依赖数据库的,所以可以先创建数据库,我是mysql数据库,所以到jbpm-4.4\install\src\db\create中找到jbpm.mysql.create.sql创建文件导入mysql执行!


2.设置spring中hibernate的配置:

可以参考:jbpm-4.4\install\src\cfg\hibernate\spring中的mysql.hibernate.cfg.xml(具体见下面的spring配置文件applicationContext.xml)


3.设置事务,这里由于hibernate和ibatis必须用一个事务,所以使用了TransactionAwareDataSourceProxy来管理事务。(具体见下面的spring配置文件applicationContext.xml)


4.配置默认jbpm的cfg文件,在classpath下创建一个jbpm.cfg.xml,内容如下:

01 <?xml version="1.0" encoding="UTF-8"?>
02  
03 <jbpm-configuration>
04  
05   <import resource="jbpm.default.cfg.xml" />
06   <import resource="jbpm.businesscalendar.cfg.xml" />
07   <!-- <import resource="jbpm.tx.hibernate.cfg.xml" /> -->
08   <import resource="jbpm.tx.spring.cfg.xml" />
09   <import resource="jbpm.jpdl.cfg.xml" />
10   <import resource="jbpm.bpmn.cfg.xml" />
11   <import resource="jbpm.identity.cfg.xml" />
12  
13   <!-- Job executor is excluded for running the example test cases. -->
14   <!-- To enable timers and messages in production use, this should be included. -->
15   <!--
16   <import resource="jbpm.jobexecutor.cfg.xml" />
17   -->
18  
19 </jbpm-configuration>

5.在spring配置文件中注入工作流引擎。(具体见下面的spring配置文件applicationContext.xml)

1 <!--jbpm4.4工作流  -->
2     <bean id="springHelper" class="org.jbpm.pvm.internal.processengine.SpringHelper"/>
3     <bean id="processEngine" factory-bean="springHelper"  factory-method="createProcessEngine" />

6.搞定以上配置文件后添加jbpm.jar, juel-api.jar,juel-engine.jar,juel-impl.jar,mail.jar,这里注意一下,可能有的朋友之后运行还会有错误如下:

java.lang.NoSuchMethodError: antlr.collections.AST.getLine()I

这是因为struts2的anltr-2.7.2.jar过旧导致的,我们为了省掉麻烦这里最好直接把struts2的antlr.jar去掉(windows---preferences---在文本框中搜索struts 2(中间有空格)---选择struts 2---选择antlr---remove),然后重新到发布到服务器的lib目录下删除anltr-2.7.2.jar即可

 

7.成功的关键就是applicationContext.xml了,这里把这个关键配置贴出来!

001 <?xml version="1.0" encoding="UTF-8"?>
002 <beans xmlns="http://www.springframework.org/schema/beans"
003     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context"
004     xmlns:aop="http://www.springframework.org/schema/aop"
005     xsi:schemaLocation="http://www.springframework.org/schema/beans
006  http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
007  http://www.springframework.org/schema/aop
008  http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
009  http://www.springframework.org/schema/context
010  http://www.springframework.org/schema/context/spring-context-2.5.xsd"default-autowire="byName">
011   
012     <context:property-placeholder location="classpath*:database.properties" />
013      
014  
015   
016     <!--jbpm4.4工作流  -->
017     <bean id="springHelper" class="org.jbpm.pvm.internal.processengine.SpringHelper"/>
018     <bean id="processEngine" factory-bean="springHelper"  factory-method="createProcessEngine" />
019      
020     <!-- dataSourceproxy 配置代理管理事务 -->
021     <bean id="dataSource"
022         class="org.springframework.jdbc.datasource.TransactionAwareDataSourceProxy"
023         p:targetDataSource-ref="dynamicDataSource" />
024      
025     <!-- dataSource 多数据源支持 -->
026     <bean id="dynamicDataSource" class="com.xuyi.support.DynamicDataSource">
027         <property name="targetDataSources">
028             <map key-type="java.lang.String">
029                 <entry key="dataSource" value-ref="dataSourceJDBC" />
030             </map>
031         </property>
032     </bean>
033      
034     <!-- c3p0数据源配置 -->
035     <bean id="dataSourceJDBC" class="com.mchange.v2.c3p0.ComboPooledDataSource"
036         destroy-method="close" p:driverClass="${jdbc.driverClass}" p:jdbcUrl="${jdbc.jdbcUrl}"
037         p:user="${jdbc.user}" p:password="${jdbc.password}" p:initialPoolSize="${c3p0.initialPoolSize}"
038         p:minPoolSize="${c3p0.minPoolSize}" p:maxPoolSize="${c3p0.maxPoolSize}"
039         p:acquireIncrement="${c3p0.acquireIncrement}" p:maxIdleTime="${c3p0.maxIdleTime}"
040         p:maxStatements="${c3p0.maxStatements}" lazy-init="true" />
041      
042  
043     <!-- hibernate-spring 基本配置 -->
044     <bean id="sessionFactory"
045         class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
046         <property name="dataSource">
047             <ref bean="dataSource" />
048         </property>
049         <property name="hibernateProperties">
050             <props>
051                 <prop key="hibernate.dialect">org.hibernate.dialect.MySQLInnoDBDialect</prop
052                 <prop key="hibernate.hbm2ddl.auto">update</prop>
053                 <prop key="hibernate.format_sql">true</prop
054             </props>
055         </property>
056         <property name="mappingLocations">
057             <list>
058                 <value>classpath*:com/xuyi/modal/Creater.hbm.xml</value>
059                 <value>classpath*:com/xuyi/modal/Month.hbm.xml</value>
060                 <value>classpath*:com/xuyi/modal/Thing.hbm.xml</value>
061                 <value>classpath*:jbpm.repository.hbm.xml</value>
062                 <value>classpath*:jbpm.execution.hbm.xml</value>
063                 <value>classpath*:jbpm.history.hbm.xml</value>
064                 <value>classpath*:jbpm.task.hbm.xml</value>
065                 <value>classpath*:jbpm.identity.hbm.xml</value>
066             </list>
067         </property>
068         <!-- 使用TransactionAwareDataSourceProxy管理事务与ibatis处于同一事务管理下 -->
069         <property name="useTransactionAwareDataSource" value="true"></property>
070     </bean>
071      
072     <!-- ibatis-spring 配置 -->
073     <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
074         <property name="dataSource" ref="dataSource"></property>
075         <property name="configLocation" value="classpath:sql-map-config.xml"></property>
076     </bean>
077  
078         <!-- spring transaction 事务管理 -->
079     <bean id="transactionManager"
080         class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
081         <property name="dataSource" ref="dataSource" />
082     </bean>
083  
084  
085     <!-- 事务代理拦截器的配置 -->
086     <bean id="transactionProxy" abstract="true"
087         class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
088         <property name="transactionManager">
089             <ref bean="transactionManager" />
090         </property>
091         <property name="transactionAttributes">
092             <props>
093                 <prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>
094                 <prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>
095                 <prop key="*">PROPAGATION_REQUIRED</prop>
096             </props>
097         </property>
098     </bean>
099  
100 </beans>
database.properties:
01 jdbc.driverClass=com.mysql.jdbc.Driver
02 jdbc.jdbcUrl=jdbc:mysql://localhost:3306/myweb
03 jdbc.user=root
04 jdbc.password=pwd
05  
06  
07 c3p0.initialPoolSize=1
08 c3p0.minPoolSize=1
09 c3p0.maxPoolSize=10
10 c3p0.acquireIncrement=5
11 c3p0.maxIdleTime=1800
12 c3p0.maxStatements=0
注意:这里会遇到一个类: com.xuyi.support.DynamicDataSource这类实现了多数据源管理。如下:
01 package com.xuyi.support;
02  
03 import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
04  
05 public class DynamicDataSourceextends AbstractRoutingDataSource {
06  
07     private static ThreadLocal<String> local = new ThreadLocal<String>();
08  
09     @Override
10     protected Object determineCurrentLookupKey() {
11         return local.get() == null ?"dataSource" : local.get();
12     }
13  
14     // ---------------------------------------------------------------------------------------------------
15  
16     /**
17      * 设置数据源路径
18      */
19     public static void setRoute(String route) {
20         if (route==null || route.equals("")){
21             route = "dataSource";
22         }
23         local.set(route);
24     }
25 }

8.终于可以开始测试了,先创建一个发布用的xml放入classpath:

测试用的流程swing.jpdl.xml
01 <?xml version="1.0" encoding="UTF-8"?>
02 <process name="swing" xmlns="http://jbpm.org/4.3/jpdl">
03    <start g="94,64,48,48" name="start1">
04       <transition g="-52,-22" name="A" to="A"/>
05    </start>
06    <task assignee="A" g="73,195,92,52" name="A">
07       <transition g="-52,-22" name="B" to="B"/>
08    </task>
09    <task assignee="B" g="266,192,92,52" name="B">
10       <transition g="-40,-21" name="end" to="end1"/>
11    </task>
12    <end g="290,327,48,48" name="end1"/>
13 </process>
然后写一个测试类进行测试:
view source
print ?
01 package com.xuyi.test;
02  
03 import java.util.List;
04  
05 import org.jbpm.api.ExecutionService;
06 import org.jbpm.api.ProcessEngine;
07 import org.jbpm.api.ProcessInstance;
08 import org.jbpm.api.TaskService;
09 import org.jbpm.api.task.Task;
10 import org.springframework.context.support.ClassPathXmlApplicationContext;
11  
12 public class TestJbpm{
13     public static void main(String[] args)  {
14         ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml");
15         applicationContext.start();
16         ProcessEngine processEngine = (ProcessEngine)applicationContext.getBean("processEngine");
17         ExecutionService executionService = processEngine.getExecutionService();
18         TaskService taskService = processEngine.getTaskService();
19  
20         //发布流程
21         String deploymentId = processEngine.getRepositoryService().createDeployment()
22         .addResourceFromClasspath("swing.jpdl.xml").deploy();
23         System.out.println("流程发布ID:"+deploymentId);
24          
25         //启动一个流程实例
26         ProcessInstance processInstance = executionService.startProcessInstanceByKey("swing");
27         System.out.println("流程实例ID:" + processInstance.getId());
28          
29  
30         //A处理任务
31         List<Task> taskList_A = taskService.findPersonalTasks("A");
32         System.out.println("A待处理任务数:" + taskList_A.size());
33         if(taskList_A.size() > 0){
34             for(Task task : taskList_A){
35                 System.out.println(task.getId());
36                 taskService.completeTask(task.getId());
37             }
38         }
39          
40         //B处理任务
41         List<Task> taskList_B = taskService.findPersonalTasks("B");
42         System.out.println("B待处理任务数:" + taskList_B.size());
43         if(taskList_B.size() > 0){
44             for(Task task : taskList_B){
45                 System.out.println(task.getId());
46                 taskService.completeTask(task.getId());
47             }
48         }
49          
50     }
51 }
 一切顺利的话就可以看到具体打印了!!关于jbpm的xml专用设计插件,可以看我以前的

在Myeclipse8.6安装JBPM插件 

这篇文章。这样设计好xml就可以发布给jbpm进行工作流处理了。

这篇关于Spring与JBPM整合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/600453

相关文章

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.