activiti报错 cvc-datatype-valid.1.2.1: ‘‘ 不是 ‘NCName‘ 的有效值。

XML解析错误:'...'非NCName有效值解析问题

org.activiti.bpmn.exceptions.XMLException: cvc-datatype-valid.1.2.1: ‘’ 不是 ‘NCName’ 的有效值。
在这里插入图片描述

2025-08-27 10:50:22,647 [(pro) WebContainer : [Anonymous][2e7a244d9514c228cbc741f274bf19c5]-opmgtask8dggpro8bdb60b0d4f874e83-7cb64c95c4-90-T:527023dc-6808-4b4f-b38e-2ff858f5d1df] ERROR AutoCompleteChange: - ChangeProcess isChangeResult:--changeNo=CT20250825074N--需求变更-----异常--------------- org.activiti.engine.ActivitiException: Error while evaluating expression: ${reqChangeListener.changeCompleteEvent(businessObjectVO,execution)} at org.activiti.engine.impl.el.JuelExpression.getValue(JuelExpression.java:57) ~[activiti-engine-5.14.jar!/:5.14] at org.activiti.engine.impl.bpmn.listener.ExpressionExecutionListener.notify(ExpressionExecutionListener.java:35) ~[activiti-engine-5.14.jar!/:5.14] at org.activiti.engine.impl.pvm.runtime.AtomicOperationTransitionNotifyListenerTake.execute(AtomicOperationTransitionNotifyListenerTake.java:48) ~[activiti-engine-5.14.jar!/:5.14] at org.activiti.engine.impl.interceptor.CommandContext.performOperation(CommandContext.java:88) ~[activiti-engine-5.14.jar!/:5.14] at org.activiti.engine.impl.persistence.entity.ExecutionEntity.performOperationSync(ExecutionEntity.java:532) ~[activiti-engine-5.14.jar!/:5.14] at org.activiti.engine.impl.persistence.entity.ExecutionEntity.performOperation(ExecutionEntity.java:527) ~[activiti-engine-5.14.jar!/:5.14] at org.activiti.engine.impl.pvm.runtime.AtomicOperationTransitionDestroyScope.execute(AtomicOperationTransitionDestroyScope.java:116) ~[activiti-engine-5.14.jar!/:5.14] at org.activiti.engine.impl.interceptor.CommandContext.performOperation(CommandContext.java:88) ~[activiti-engine-5.14.jar!/:5.14] at org.activiti.engine.impl.persistence.entity.ExecutionEntity.performOperationSync(ExecutionEntity.java:532) ~[activiti-engine-5.14.jar!/:5.14] at org.activiti.engine.impl.persistence.entity.ExecutionEntity.performOperation(ExecutionEntity.java:527) ~[activiti-engine-5.14.jar!/:5.14] at org.activiti.engine.impl.pvm.runtime.AtomicOperationTransitionNotifyListenerEnd.eventNotificationsCompleted(AtomicOperationTransitionNotifyListenerEnd.java... 帮忙分析下错误原因
最新发布
08-28
从你提供的日志来看,这是一个与 **Activiti 工作流引擎** 相关的异常。错误信息如下: ``` org.activiti.engine.ActivitiException: Error while evaluating expression: ${reqChangeListener.changeCompleteEvent(businessObjectVO,execution)} ``` ### 错误原因分析: 这个错误表明在 Activiti 引擎尝试执行一个表达式 `${reqChangeListener.changeCompleteEvent(businessObjectVO,execution)}` 时,出现了异常。 #### 可能的原因包括: --- ### 1. **reqChangeListener 未被正确注入或注册为 Spring Bean** Activiti 使用 Spring EL 或 JUEL 表达式来调用 Java 对象的方法。如果 `reqChangeListener` 这个 bean 没有在 Spring 容器中注册,或者没有正确注入到 Activiti 的上下文中,就会导致这个错误。 --- ### 2. **方法签名不匹配** `changeCompleteEvent(businessObjectVO, execution)` 方法的参数类型或数量不匹配。Activiti 在调用该方法时传入的参数可能与 Java 方法定义不一致。 例如: ```java public void changeCompleteEvent(BusinessObjectVO businessObjectVO, DelegateTask execution) { ... } ``` 而 Activiti 实际上传入的可能是 `DelegateExecution` 类型,而不是 `DelegateTask`。 --- ### 3. **businessObjectVO 或 execution 为 null** 表达式中的参数 `businessObjectVO` 或 `execution` 可能未在流程变量中设置,导致传递 `null` 给方法,从而抛出异常(如 NullPointerException 或参数类型不匹配)。 --- ### 4. **表达式写法不正确** Activiti 使用的是 JUEL 表达式解析器(旧版本如 5.14),它对表达式语法的支持可能不如 Spring EL 那么强大。如果你的方法参数是复杂对象,可能无法自动转换。 --- ## ✅ 解决方案 ### ✅ 1. 检查 reqChangeListener 是否被正确注册为 Spring Bean 确保你在 Spring 配置中正确注册了该类为 Bean: ```java @Component("reqChangeListener") public class ReqChangeListener { public void changeCompleteEvent(BusinessObjectVO businessObjectVO, DelegateExecution execution) { // do something } } ``` ### ✅ 2. 确保方法签名与传入参数匹配 Activiti 在流程执行过程中传入的通常是 `DelegateExecution` 而不是 `DelegateTask`: ```java public void changeCompleteEvent(BusinessObjectVO businessObjectVO, DelegateExecution execution) { // 方法体 } ``` ### ✅ 3. 检查流程变量是否正确设置 确保 `businessObjectVO` 和 `execution` 在流程上下文中存在且不为 null。 你可以通过流程变量注入方式传递: ```java Map<String, Object> variables = new HashMap<>(); variables.put("businessObjectVO", businessObjectVO); runtimeService.startProcessInstanceByKey("yourProcessKey", variables); ``` 或者在流程定义中使用正确的变量名。 --- ### ✅ 4. 升级 Activiti 版本(可选) Activiti 5.14 是一个非常老的版本,很多表达式支持和 Spring 集成不如新版本(如 Activiti 6+ 或 Activiti Cloud)。如果可以升级,推荐升级到更新版本以获得更好的兼容性。 --- ### ✅ 5. 添加日志和 try-catch 来调试 你可以在 `changeCompleteEvent` 方法中添加 try-catch 和日志输出,查看具体抛出的异常: ```java public void changeCompleteEvent(BusinessObjectVO businessObjectVO, DelegateExecution execution) { try { // 你的逻辑 } catch (Exception e) { logger.error("Error in changeCompleteEvent", e); throw new RuntimeException("Failed to execute changeCompleteEvent", e); } } ``` 这样你可以在日志中看到更详细的异常堆栈。 --- ##
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值