步骤流程中日志记录方案(类aop)

一、背景介绍

在某个诉讼管理系统中,诉讼流程通常包含以下几个关键节点:

  • 起诉(lawsuit filing)

  • 开庭(hearing open)

  • 判决(judgment)

  • 执行(enforcement)

  • 和解(settlement)

每个节点都会涉及:

  1. 更新诉讼状态(如从"起诉中"改为"已开庭")。

  2. 写入诉讼流程记录(记录诉讼进展)。

  3. 上传相关文件(如庭审材料、判决书等)。

  4. 记录日志(保证操作可追溯)。


二、统一日志方法

这里定义了一个公共方法 addLog,用于统一插入日志表:

复制代码
void addLog(Long loanId, String bizTableName, Long bizTableId,
            String opType, String opContent, String opUser);

抽象出一个通用日志方法 addLog,方便在不同流程节点调用:

复制代码
@Override
public void addLog(Long loanId, String bizTableName, Long bizTableId,
                   String opType, String opContent, String opUser) {
    LoanInLogDO log = new LoanInLogDO();
    log.setLoanId(loanId);
    log.setBizTableName(bizTableName);
    log.setBizTableId(bizTableId);
    log.setOpType(opType);
    log.setOpContent(opContent);
    log.setOpUser(opUser);
    log.setCreateTime(LocalDateTime.now());
    loanInLogMapper.insert(log);
}

📌 优点

  • 所有日志操作走一个方法,避免重复代码。

  • 保证日志数据结构一致性,方便后续审计。


三、诉讼流程接口

1. 起诉(Lawsuit Filing)

复制代码
@PostMapping("/lawsuit/file")
@Operation(summary = "起诉:新增诉讼信息并写日志")
@PreAuthorize("@ss.hasPermission('bank:loan-out-lawsuit:create')")
public CommonResult<LawsuitRespVO> fileLawsuit(@Valid @RequestBody LawsuitReqVO reqVO) {
    AdminUserDO user = userService.getUser(getLoginUserId());
    LawsuitRespVO resp = loanOutLawsuitService.file(reqVO);

    loanOutLogService.addLog(
        resp.getLoanId(),
        "loan_out_lawsuit",
        resp.getId(),
        "诉讼操作",
        "发起起诉",
        user.getNickname()
    );
    return success(resp);
}

逻辑分解:

  1. 安全控制
    @PreAuthorize 确保只有具备权限的用户才能调用。

  2. 参数绑定

    • @ModelAttribute HearingOpenReqVO hearing:接收开庭请求参数。

    • @RequestParam List<MultipartFile> files:接收上传的证据文件。

  3. 业务处理

    调用 loanOutLawsuitRecordService.openHearing() 完成:

    • 写入诉讼流程记录

    • 更新诉讼状态为"开庭"

    • 保存上传的文件

  4. 日志记录

    统一调用 addLog,插入一条日志:

    • 类型:诉讼操作

    • 内容:更改为开庭状态

    • 操作人:当前登录用户


四、整体价值

这种写法的好处是:

  • 日志方法抽象 :不论是"开庭"、"判决"、"和解",都能统一调用 addLog,保证日志字段一致性。

  • 接口职责清晰:Controller 只负责调用 Service 并记录日志,业务逻辑集中在 Service 中。

  • 审计追踪:每个诉讼流程操作都有可追溯的日志记录,方便后续审计或问题排查。

相关推荐
oak隔壁找我5 小时前
JVM常用调优参数
java·后端
蝎子莱莱爱打怪9 小时前
OpenClaw 从零配置指南:接入飞书 + 常用命令 + 原理图解
java·后端·ai编程
狼爷10 小时前
Go 没有 override?别硬套继承!用接口+嵌入,写更清爽的“覆盖”逻辑
java·go
小兔崽子去哪了13 小时前
Java 自动化部署
java·后端
ma_king13 小时前
入门 java 和 数据库
java·数据库·后端
后端AI实验室13 小时前
我用Cursor开发了3个月,整理出这套提效4倍的工作流
java·ai
码路飞17 小时前
GPT-5.3 Instant 终于学会好好说话了,顺手对比了下同天发布的 Gemini 3.1 Flash-Lite
java·javascript
SimonKing18 小时前
OpenCode AI编程助手如何添加Skills,优化项目!
java·后端·程序员
Seven9719 小时前
剑指offer-80、⼆叉树中和为某⼀值的路径(二)
java
怒放吧德德1 天前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty