审批模板核心结构包含三部分:审批节点定义、流转规则、状态管理;节点用POJO定义并支持动态处理人,流转通过策略+责任链实现配置驱动,状态变更由受控枚举方法保障合法性。

审批模板的核心结构
Java中构建流程审批模板,关键不是写死逻辑,而是设计可配置、可扩展的结构。一个简单但实用的模板通常包含三部分:审批节点定义、流转规则、状态管理。节点不绑定具体人,而是用角色、表达式或外部服务动态决定处理人;流转不硬编码if-else,而是靠条件判断+配置驱动;状态不靠字符串拼接,而是用枚举+有限状态机思想约束合法变更。
用POJO定义审批节点和流程
先建两个基础类,保持轻量清晰:
-
ApproveNode:含id、name、role(如“部门经理”)、condition(SpEL表达式,如#order.amount > 5000)、nextNodes(List
) -
ApproveProcess:含processId、startNodeId、nodes(Map
)、status(ApproveStatus枚举)
这样节点可序列化、可存数据库或YAML,后续增删节点只需改配置,不碰Java代码。
用策略+责任链实现动态审批流转
避免在Service里堆满switch或if。推荐组合使用:
立即学习“Java免费学习笔记(深入)”;
- 定义ApproveHandler接口,每个实现类专注一种审批动作(如邮件通知、调用HR系统查岗级)
- 用Map
按nodeId注册处理器,运行时根据当前节点查出对应handler执行 - 流转决策交给ApproveRouter:接收当前节点+业务上下文(如Order对象),解析condition表达式,返回下一个节点ID列表
例如:提交报销单后,router计算出“金额≤2000→直属主管审批”,自动触发主管节点的handler,无需修改主流程代码。
状态变更必须受控,禁止随意set
审批状态(草稿/待审/已通过/已驳回/已终止)不能直接public set。正确做法:
- ApproveProcess里status字段private,只提供transitionTo(NextAction action)方法
- NextAction是枚举(SUBMIT / APPROVE / REJECT / RETURN),每个值内置校验逻辑:比如只有状态为“待审”才允许APPROVE
- 变更前记录操作人、时间、备注,便于追溯
这样哪怕前端传错参数,后端也能拦截非法状态跳转,保障流程完整性。
基本上就这些。不复杂但容易忽略——结构松耦合、状态严管控、流转可配置,才是“简单模板”能长期维护的关键。











