Camunda工作流集成SpringBoot(三)

Camunda监听

书接上回Camunda工作流集成SpringBoot(二)
两种常用的监听方式

监听位置

start:启动监听 不能加在序列流上面
end:结束监听 不能加在序列流上面
take:执行监听 只能加在序列流上面
create:流程启动
assigment:流程部署
complete:流程完成
delete:流程结束

ExecutionListener

直接写js脚本的方式

1.选择lnline Script,则Script里面写javascript的实现方式
在这里插入图片描述
2.引用脚本路径的方式
Script Type选择External Resource,则Resource需要写js脚本的路径

在这里插入图片描述
这里的路径为classes下的路径
在这里插入图片描述
这种方式适用于WebSocket,或者node可以直接可以跑的js脚本

Java Class方式的监听

ExecutionListener
在这里插入图片描述
映射的java类实现ExecutionListener接口,一旦出发绑定的节点则会自动触发notify方法

package org.example.listener;

import org.camunda.bpm.engine.delegate.DelegateExecution;

import org.camunda.bpm.engine.delegate.ExecutionListener;
import org.camunda.bpm.engine.delegate.Expression;
public class MyTaskListener implements ExecutionListener {
	//field injection
    private Expression message;
    @Override
    public void notify(DelegateExecution delegateExecution) throws Exception {
        System.out.println((String) message.getValue(delegateExecution));
    }
}

另外Field injection用来给监听器传参
在这里插入图片描述
在java代码中需要定义成Expression的对象 名称和name保持一致

//获取变量
System.out.println((String) message.getValue(delegateExecution));

TaskListener

在这里插入图片描述
TaskListener可以监听流程创建销毁等等与业务无关的操作
java代码与ExepressionListener大体一致,不同的是TaskListener的java类实现的是TaskListener接口

public class MyTaskListener implements TaskListener {
	@Overrids
	public void notify(DelegateExecution delegateExecution) throws Exception {
		...
	}
}
  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
你可以按照以下步骤将Camunda工作流集成Spring Boot项目中: 1. 添加Camunda依赖:在项目的pom.xml文件中添加Camunda依赖。你可以根据需要选择特定的Camunda版本,例如: ```xml <dependency> <groupId>org.camunda.bpm.springboot</groupId> <artifactId>camunda-bpm-spring-boot-starter</artifactId> <version>7.15.0</version> </dependency> ``` 2. 配置Camunda:在Spring Boot项目的application.properties或application.yml文件中添加以下Camunda相关配置: ```properties # 数据库配置 spring.datasource.url=jdbc:h2:mem:camunda;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE spring.datasource.username=sa spring.datasource.password= spring.datasource.driver-class-name=org.h2.Driver # Camunda配置 spring.jpa.database-platform=org.hibernate.dialect.H2Dialect camunda.bpm.database.schema-update=true # Camunda REST API配置(可选) camunda.bpm.rest.enabled=true camunda.bpm.rest.authentication-enabled=false ``` 上述配置使用了内存数据库H2,你可以根据需要选择其他数据库,并相应地修改配置。 3. 创建工作流定义:在项目的resources目录下创建一个`.bpmn`或`.bpmn20.xml`文件来定义工作流程。你可以使用Camunda Modeler等工具进行图形化编辑,也可以手动编写XML。 4. 编写服务类:创建一个Java类来定义Camunda服务。你可以使用`@Component`、`@Service`或`@RestController`等注解将该类注册为Spring Bean,并实现所需的工作流逻辑。 5. 启动应用程序:编写一个启动类(例如,添加了`@SpringBootApplication`注解的类),以启动Spring Boot应用程序。 完成以上步骤后,你的Spring Boot应用程序将集成Camunda工作流引擎,并可使用工作流定义和自定义服务类来执行工作流程。 注意:以上步骤提供了一个基本的集成示例,你可以根据实际需求进行调整和扩展。有关更多详细信息和高级配置,请参考CamundaSpring Boot的官方文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

商朝

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值