Files
ccdi/docs/plans/2026-03-02-lsfx-update-plan.md
wkc b022ec75b8 fix(lsfx): 修复流水分析对接模块的代码质量问题
1. 修复配置问题
   - 替换app-secret占位符为正确的密钥dXj6eHRmPv

2. 添加异常处理
   - HttpUtil所有方法添加完整的异常处理
   - 统一使用LsfxApiException包装异常
   - 检查HTTP状态码和响应体

3. 添加日志记录
   - Client所有方法添加详细的日志记录
   - 记录请求参数、响应结果、耗时
   - 异常情况记录错误日志

4. 完善参数校验
   - 接口1:添加6个必填字段校验
   - 接口2:添加groupId和文件校验,限制文件大小10MB
   - 接口3:添加7个参数校验和日期范围校验
   - 接口4:添加groupId和inprogressList校验

5. 性能优化
   - RestTemplate使用Apache HttpClient连接池
   - 最大连接数100,每个路由最大20个连接
   - 支持连接复用,提升性能

6. 代码审查文档
   - 添加详细的代码审查报告
   - 记录发现的问题和改进建议

修改的文件:
- ccdi-lsfx/pom.xml
- ccdi-lsfx/src/main/java/com/ruoyi/lsfx/client/LsfxAnalysisClient.java
- ccdi-lsfx/src/main/java/com/ruoyi/lsfx/config/RestTemplateConfig.java
- ccdi-lsfx/src/main/java/com/ruoyi/lsfx/controller/LsfxTestController.java
- ccdi-lsfx/src/main/java/com/ruoyi/lsfx/util/HttpUtil.java
- ruoyi-admin/src/main/resources/application-dev.yml
- doc/implementation/lsfx-code-review-20260302.md
2026-03-03 09:35:27 +08:00

26 KiB
Raw Permalink Blame History

流水分析接口更新实施计划

For Claude: REQUIRED SUB-SKILL: Use superpowers:executing-plans to implement this plan task-by-task.

目标: 按照新版接口文档完全重构流水分析模块更新接口2、3、4、7删除接口5、6

架构: 基于Spring Boot 3的REST API客户端模块使用RestTemplate进行HTTP调用Lombok简化DTO定义

技术栈: Spring Boot 3.5.8, Java 17, Lombok, RestTemplate, SpringDoc OpenAPI

前置条件:

  • 项目已存在 ccdi-lsfx 模块
  • 现有7个接口的DTO和Client已实现
  • 需要参考新版文档:doc/对接流水分析/兰溪-流水分析对接-新版.md

任务概览

任务 说明 文件数
Task 1 更新配置文件 1
Task 2 删除废弃DTO类 3
Task 3 重构接口2上传文件Response 1
Task 4 重构接口3拉取行内流水Request和Response 2
Task 5 重构接口4检查解析状态Response 1
Task 6 重构接口7获取流水Request和Response 2
Task 7 更新Client客户端 1
Task 8 更新TestController 1
Task 9 编译验证和测试 -

Task 1: 更新配置文件

文件:

  • 修改: ruoyi-admin/src/main/resources/application-dev.yml:105-130

步骤 1: 删除接口5和接口6的配置项

定位到 lsfx.api.endpoints 部分,删除以下两行:

      generate-report: /watson/api/project/confirmStageUploadLogs
      check-report-status: /watson/api/project/upload/getallpendings

步骤 2: 更新接口7的路径

修改 get-bank-statement 配置:

      # 旧路径get-bank-statement: /watson/api/project/upload/getBankStatement
      get-bank-statement: /watson/api/project/getBSByLogId  # 新路径

步骤 3: 验证配置

完整的endpoints配置应该是

    endpoints:
      get-token: /account/common/getToken
      upload-file: /watson/api/project/remoteUploadSplitFile
      fetch-inner-flow: /watson/api/project/getJZFileOrZjrcuFile
      check-parse-status: /watson/api/project/upload/getpendings
      get-bank-statement: /watson/api/project/getBSByLogId

步骤 4: 提交配置更新

git add ruoyi-admin/src/main/resources/application-dev.yml
git commit -m "config(lsfx): 删除接口5、6配置更新接口7路径"

Task 2: 删除废弃DTO类

文件:

  • 删除: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/request/GenerateReportRequest.java
  • 删除: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/GenerateReportResponse.java
  • 删除: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/CheckReportStatusResponse.java

步骤 1: 删除GenerateReportRequest.java

rm ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/request/GenerateReportRequest.java

步骤 2: 删除GenerateReportResponse.java

rm ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/GenerateReportResponse.java

步骤 3: 删除CheckReportStatusResponse.java

rm ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/CheckReportStatusResponse.java

步骤 4: 提交删除操作

git add -A ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/
git commit -m "refactor(lsfx): 删除接口5生成报告和接口6检查报告状态的DTO类"

Task 3: 重构接口2上传文件Response DTO

文件:

  • 重写: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/UploadFileResponse.java

步骤 1: 完全重写UploadFileResponse.java

用以下完整代码替换整个文件:

package com.ruoyi.lsfx.domain.response;

import lombok.Data;
import java.util.List;
import java.util.Map;

/**
 * 上传文件响应完整版匹配新文档2.5节)
 */
@Data
public class UploadFileResponse {

    /** 返回码 */
    private String code;

    /** 状态 */
    private String status;

    /** 成功标识 */
    private Boolean successResponse;

    /** 响应数据 */
    private UploadData data;

    @Data
    public static class UploadData {
        /** 账号映射信息key为logId */
        private Map<String, List<AccountInfo>> accountsOfLog;

        /** 上传日志列表 */
        private List<UploadLogItem> uploadLogList;

        /** 上传状态 */
        private Integer uploadStatus;
    }

    @Data
    public static class AccountInfo {
        /** 所属银行 */
        private String bank;

        /** 账号名称 */
        private String accountName;

        /** 账号 */
        private String accountNo;

        /** 币种 */
        private String currency;
    }

    @Data
    public static class UploadLogItem {
        /** 账号列表 */
        private List<String> accountNoList;

        /** 银行名称 */
        private String bankName;

        /** 数据类型信息 [格式, 分隔符] */
        private List<String> dataTypeInfo;

        /** 下载文件名 */
        private String downloadFileName;

        /** 企业名称列表 */
        private List<String> enterpriseNameList;

        /** 文件包ID */
        private String filePackageId;

        /** 文件大小(字节) */
        private Long fileSize;

        /** 上传用户ID */
        private Integer fileUploadBy;

        /** 上传用户名 */
        private String fileUploadByUserName;

        /** 上传时间 */
        private String fileUploadTime;

        /** 企业ID */
        private Integer leId;

        /** 文件ID重要 */
        private Integer logId;

        /** 日志元数据 */
        private String logMeta;

        /** 日志类型 */
        private String logType;

        /** 登录企业ID */
        private Integer loginLeId;

        /** 真实银行名称 */
        private String realBankName;

        /** 行数 */
        private Integer rows;

        /** 来源 */
        private String source;

        /** 状态(-5表示成功 */
        private Integer status;

        /** 模板名称 */
        private String templateName;

        /** 总记录数 */
        private Integer totalRecords;

        /** 交易结束日期ID */
        private Integer trxDateEndId;

        /** 交易开始日期ID */
        private Integer trxDateStartId;

        /** 上传文件名 */
        private String uploadFileName;

        /** 上传状态描述 */
        private String uploadStatusDesc;
    }
}

步骤 2: 提交更改

git add ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/UploadFileResponse.java
git commit -m "refactor(lsfx): 重构接口2 Response添加完整字段accountsOfLog、uploadLogList"

Task 4: 重构接口3拉取行内流水Request和Response DTO

文件:

  • 重写: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/request/FetchInnerFlowRequest.java
  • 重写: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/FetchInnerFlowResponse.java

步骤 1: 完全重写FetchInnerFlowRequest.java

用以下代码替换整个文件:

package com.ruoyi.lsfx.domain.request;

import lombok.Data;

/**
 * 拉取行内流水请求参数匹配新文档3.2节)
 */
@Data
public class FetchInnerFlowRequest {

    /** 项目ID */
    private Integer groupId;

    /** 客户身份证号 */
    private String customerNo;

    /** 数据渠道编码固定值ZJRCU */
    private String dataChannelCode;

    /** 发起请求的时间格式yyyyMMdd */
    private Integer requestDateId;

    /** 拉取开始日期格式yyyyMMdd */
    private Integer dataStartDateId;

    /** 拉取结束日期格式yyyyMMdd */
    private Integer dataEndDateId;

    /** 柜员号 */
    private Integer uploadUserId;
}

步骤 2: 完全重写FetchInnerFlowResponse.java

用以下代码替换整个文件:

package com.ruoyi.lsfx.domain.response;

import lombok.Data;

/**
 * 拉取行内流水响应匹配新文档3.5节)
 */
@Data
public class FetchInnerFlowResponse {

    /** 返回码 */
    private String code;

    /** 状态 */
    private String status;

    /** 成功标识 */
    private Boolean successResponse;

    /** 响应数据 */
    private FetchData data;

    @Data
    public static class FetchData {
        /** 状态码501014表示无行内流水文件 */
        private String code;

        /** 消息(如:无行内流水文件) */
        private String message;
    }
}

步骤 3: 提交更改

git add ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/request/FetchInnerFlowRequest.java
git add ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/FetchInnerFlowResponse.java
git commit -m "refactor(lsfx): 重构接口3 Request/Response修正参数名和字段结构"

Task 5: 重构接口4检查解析状态Response DTO

文件:

  • 重写: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/CheckParseStatusResponse.java

步骤 1: 完全重写CheckParseStatusResponse.java

用以下代码替换整个文件:

package com.ruoyi.lsfx.domain.response;

import lombok.Data;
import java.util.List;

/**
 * 检查文件解析状态响应匹配新文档4.5节)
 */
@Data
public class CheckParseStatusResponse {

    /** 返回码 */
    private String code;

    /** 状态 */
    private String status;

    /** 成功标识 */
    private Boolean successResponse;

    /** 响应数据 */
    private ParseStatusData data;

    @Data
    public static class ParseStatusData {
        /** 是否正在解析true=解析中false=解析结束)- 关键字段 */
        private Boolean parsing;

        /** 待处理文件列表 */
        private List<PendingItem> pendingList;
    }

    @Data
    public static class PendingItem {
        /** 账号列表 */
        private List<String> accountNoList;

        /** 银行名称 */
        private String bankName;

        /** 数据类型信息 */
        private List<String> dataTypeInfo;

        /** 下载文件名 */
        private String downloadFileName;

        /** 企业名称列表 */
        private List<String> enterpriseNameList;

        /** 文件包ID */
        private String filePackageId;

        /** 文件大小(字节) */
        private Long fileSize;

        /** 上传用户ID */
        private Integer fileUploadBy;

        /** 上传用户名 */
        private String fileUploadByUserName;

        /** 上传时间 */
        private String fileUploadTime;

        /** 是否拆分 */
        private Integer isSplit;

        /** 企业ID */
        private Integer leId;

        /** 文件ID重要 */
        private Integer logId;

        /** 日志元数据 */
        private String logMeta;

        /** 日志类型 */
        private String logType;

        /** 登录企业ID */
        private Integer loginLeId;

        /** 丢失的表头 */
        private List<String> lostHeader;

        /** 真实银行名称 */
        private String realBankName;

        /** 行数 */
        private Integer rows;

        /** 来源 */
        private String source;

        /** 状态(-5表示成功 */
        private Integer status;

        /** 模板名称 */
        private String templateName;

        /** 总记录数 */
        private Integer totalRecords;

        /** 交易结束日期ID */
        private Integer trxDateEndId;

        /** 交易开始日期ID */
        private Integer trxDateStartId;

        /** 上传文件名 */
        private String uploadFileName;

        /** 上传状态描述data.wait.confirm.newaccount表示成功 */
        private String uploadStatusDesc;
    }
}

步骤 2: 提交更改

git add ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/CheckParseStatusResponse.java
git commit -m "refactor(lsfx): 重构接口4 Response添加parsing字段和完整pendingList"

Task 6: 重构接口7获取流水Request和Response DTO

文件:

  • 重写: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/request/GetBankStatementRequest.java
  • 重写: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/GetBankStatementResponse.java

步骤 1: 完全重写GetBankStatementRequest.java

用以下代码替换整个文件:

package com.ruoyi.lsfx.domain.request;

import lombok.Data;

/**
 * 获取银行流水请求参数匹配新文档6.2节)
 */
@Data
public class GetBankStatementRequest {

    /** 项目ID */
    private Integer groupId;

    /** 文件ID新增必填参数 */
    private Integer logId;

    /** 当前页码原pageNum */
    private Integer pageNow;

    /** 每页数量 */
    private Integer pageSize;
}

步骤 2: 完全重写GetBankStatementResponse.java

用以下完整代码替换整个文件包含40+字段的BankStatementItem

package com.ruoyi.lsfx.domain.response;

import lombok.Data;
import java.math.BigDecimal;
import java.util.List;

/**
 * 获取银行流水响应匹配新文档6.5节)
 */
@Data
public class GetBankStatementResponse {

    /** 返回码 */
    private String code;

    /** 状态 */
    private String status;

    /** 成功标识 */
    private Boolean successResponse;

    /** 响应数据 */
    private BankStatementData data;

    @Data
    public static class BankStatementData {
        /** 流水列表 */
        private List<BankStatementItem> bankStatementList;

        /** 总条数 */
        private Integer totalCount;
    }

    @Data
    public static class BankStatementItem {
        // ===== 账号相关信息 =====

        /** 流水ID */
        private Long bankStatementId;

        /** 企业ID */
        private Integer leId;

        /** 账号ID */
        private Long accountId;

        /** 企业账号名称 */
        private String leName;

        /** 企业银行账号 */
        private String accountMaskNo;

        /** 账号日期ID */
        private Integer accountingDateId;

        /** 账号日期 */
        private String accountingDate;

        /** 交易日期 */
        private String trxDate;

        /** 币种 */
        private String currency;

        // ===== 交易金额 =====

        /** 付款金额 */
        private BigDecimal drAmount;

        /** 收款金额 */
        private BigDecimal crAmount;

        /** 余额 */
        private BigDecimal balanceAmount;

        /** 交易金额 */
        private BigDecimal transAmount;

        // ===== 交易类型和标志 =====

        /** 交易类型 */
        private String cashType;

        /** 交易标志位 */
        private String transFlag;

        /** 分类ID */
        private Integer transTypeId;

        /** 异常类型 */
        private String exceptionType;

        // ===== 对手方信息 =====

        /** 对手方企业ID */
        private Integer customerId;

        /** 对手方企业名称 */
        private String customerName;

        /** 对手方账号 */
        private String customerAccountMaskNo;

        /** 对手方银行 */
        private String customerBank;

        /** 对手方备注 */
        private String customerReference;

        // ===== 摘要和备注 =====

        /** 用户交易摘要 */
        private String userMemo;

        /** 银行交易摘要 */
        private String bankComments;

        /** 银行交易号 */
        private String bankTrxNumber;

        // ===== 银行信息 =====

        /** 所属银行缩写 */
        private String bank;

        // ===== 其他字段 =====

        /** 是否为内部交易 */
        private Integer internalFlag;

        /** 上传logId */
        private Integer batchId;

        /** 项目id */
        private Integer groupId;

        /** 覆盖标识 */
        private Long overrideBsId;

        /** 交易方式 */
        private String paymentMethod;

        /** 客户账号掩码号 */
        private String cretNo;

        // ===== 附加字段 =====

        /** 附件数量 */
        private Integer attachments;

        /** 评论数 */
        private Integer commentsNum;

        /** 归档标志 */
        private Integer archivingFlag;

        /** 下付款标志 */
        private Integer downPaymentFlag;

        /** 源目录ID */
        private Integer sourceCatalogId;

        /** 拆分标志 */
        private Integer split;

        /** 子流水ID */
        private Long subBankstatementId;

        /** 待办标志 */
        private Integer toDoFlag;

        /** 转换金额 */
        private BigDecimal transformAmount;

        /** 转换收款金额 */
        private BigDecimal transformCrAmount;

        /** 转换付款金额 */
        private BigDecimal transformDrAmount;

        /** 转换余额 */
        private BigDecimal transfromBalanceAmount;

        /** 交易余额 */
        private BigDecimal trxBalance;
    }
}

步骤 3: 提交更改

git add ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/request/GetBankStatementRequest.java
git add ccdi-lsfx/src/main/java/com/ruoyi/lsfx/domain/response/GetBankStatementResponse.java
git commit -m "refactor(lsfx): 重构接口7 Request/Response新路径、新参数、完整字段"

Task 7: 更新LsfxAnalysisClient客户端类

文件:

  • 修改: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/client/LsfxAnalysisClient.java

步骤 1: 删除接口5和接口6的相关代码

删除以下内容:

  1. 删除字段注入约第48-52行
    @Value("${lsfx.api.endpoints.generate-report}")
    private String generateReportEndpoint;

    @Value("${lsfx.api.endpoints.check-report-status}")
    private String checkReportStatusEndpoint;
  1. 删除 generateReport() 方法约第127-134行

  2. 删除 checkReportStatus() 方法约第139-146行

步骤 2: 更新import语句

确保import中已删除

// 确保这些import被删除
import com.ruoyi.lsfx.domain.request.GenerateReportRequest;
import com.ruoyi.lsfx.domain.response.GenerateReportResponse;
import com.ruoyi.lsfx.domain.response.CheckReportStatusResponse;

步骤 3: 更新方法注释

更新 getBankStatement() 方法的注释:

/**
 * 获取银行流水(新版接口)
 * 注意需要传入logId参数参数名已从pageNum改为pageNow
 *
 * @param request 请求参数groupId, logId, pageNow, pageSize
 * @return 流水明细列表
 */
public GetBankStatementResponse getBankStatement(GetBankStatementRequest request) {
    String url = baseUrl + getBankStatementEndpoint;

    Map<String, String> headers = new HashMap<>();
    headers.put(LsfxConstants.HEADER_CLIENT_ID, clientId);

    return httpUtil.postJson(url, request, headers, GetBankStatementResponse.class);
}

步骤 4: 提交更改

git add ccdi-lsfx/src/main/java/com/ruoyi/lsfx/client/LsfxAnalysisClient.java
git commit -m "refactor(lsfx): Client删除接口5、6方法更新接口7注释"

Task 8: 更新LsfxTestController测试控制器

文件:

  • 修改: ccdi-lsfx/src/main/java/com/ruoyi/lsfx/controller/LsfxTestController.java

步骤 1: 删除接口5和接口6的测试方法

删除以下两个方法:

  1. generateReport() 方法约第697-703行
  2. checkReportStatus() 方法约第705-711行

步骤 2: 删除相关import

确保删除:

import com.ruoyi.lsfx.domain.request.GenerateReportRequest;
import com.ruoyi.lsfx.domain.response.GenerateReportResponse;
import com.ruoyi.lsfx.domain.response.CheckReportStatusResponse;

步骤 3: 更新接口7的Swagger注释和参数验证

更新 getBankStatement() 方法:

@Operation(summary = "获取银行流水列表(新版)",
           description = "分页获取指定文件的银行流水数据需要提供logId参数")
@PostMapping("/getBankStatement")
public AjaxResult getBankStatement(@RequestBody GetBankStatementRequest request) {
    // 参数校验
    if (request.getGroupId() == null) {
        return AjaxResult.error("参数不完整groupId为必填");
    }
    if (request.getLogId() == null) {
        return AjaxResult.error("参数不完整logId为必填文件ID");
    }
    if (request.getPageNow() == null || request.getPageNow() < 1) {
        return AjaxResult.error("参数不完整pageNow为必填且大于0");
    }
    if (request.getPageSize() == null || request.getPageSize() < 1) {
        return AjaxResult.error("参数不完整pageSize为必填且大于0");
    }

    GetBankStatementResponse response = lsfxAnalysisClient.getBankStatement(request);
    return AjaxResult.success(response);
}

步骤 4: 提交更改

git add ccdi-lsfx/src/main/java/com/ruoyi/lsfx/controller/LsfxTestController.java
git commit -m "refactor(lsfx): Controller删除接口5、6测试接口更新接口7参数验证"

Task 9: 编译验证和测试

步骤 1: 编译项目

mvn clean compile

预期输出:

[INFO] BUILD SUCCESS
[INFO] Total time: XX.XXX s

如果编译失败:

  • 检查是否有残留的import语句引用已删除的类
  • 检查DTO类中的字段类型是否正确
  • 查看编译错误信息并修复

步骤 2: 启动应用

cd ruoyi-admin
mvn spring-boot:run

预期输出:

Application started successfully

步骤 3: 访问Swagger UI

浏览器访问:http://localhost:8080/swagger-ui/index.html

验证项:

  1. 确认接口5生成报告和接口6检查报告状态已消失
  2. 确认接口7的路径显示为 /lsfx/test/getBankStatement
  3. 点击接口7查看Schema确认Request包含4个字段groupId, logId, pageNow, pageSize
  4. 查看Response Schema确认包含完整的BankStatementItem字段

步骤 4: 测试接口1获取Token

使用Swagger或curl测试

curl -X POST http://localhost:8080/lsfx/test/getToken \
  -H "Content-Type: application/json" \
  -d '{
    "projectNo": "902000_'$(date +%s)'",
    "entityName": "测试项目",
    "userId": "902001",
    "userName": "902001",
    "orgCode": "902000",
    "departmentCode": "902000"
  }'

预期响应:

{
  "code": 200,
  "msg": "操作成功",
  "data": {
    "code": "200",
    "data": {
      "token": "eyJ0eXAi...",
      "projectId": 123,
      ...
    }
  }
}

步骤 5: 查看git状态

git status
git log --oneline -5

预期看到5个提交:

xxxxxxx refactor(lsfx): Controller删除接口5、6测试接口更新接口7参数验证
xxxxxxx refactor(lsfx): Client删除接口5、6方法更新接口7注释
xxxxxxx refactor(lsfx): 重构接口7 Request/Response新路径、新参数、完整字段
xxxxxxx refactor(lsfx): 重构接口4 Response添加parsing字段和完整pendingList
xxxxxxx refactor(lsfx): 重构接口3 Request/Response修正参数名和字段结构
...

步骤 6: 创建总结报告

doc/implementation/ 目录下创建实施报告:

cat > doc/implementation/lsfx-update-report-$(date +%Y%m%d).md << 'EOF'
# 流水分析接口更新实施报告

## 实施日期
$(date +%Y-%m-%d)

## 更新内容

### 删除的接口
- 接口5生成尽调报告/watson/api/project/confirmStageUploadLogs
- 接口6检查报告生成状态/watson/api/project/upload/getallpendings

### 重构的接口
- 接口2上传文件Response - 添加完整字段accountsOfLog、uploadLogList
- 接口3拉取行内流水 - 修正Request参数名重构Response结构
- 接口4检查解析状态 - 添加parsing字段完善pendingList结构
- 接口7获取流水 - 新路径、新参数logId、pageNow、完整40+字段

### 保留的接口
- 接口1获取Token - 无需修改

## 修改的文件统计
- 配置文件1个
- 删除的DTO类3个
- 重构的DTO类6个
- 更新的Java类2个
- 总计12个文件

## 测试结果
- 编译状态:✅ 成功
- 启动状态:✅ 成功
- Swagger UI✅ 接口正常显示
- 接口1测试✅ 返回正常

## 待办事项
- [ ] 与前端联调测试新接口参数
- [ ] 生产环境配置更新
- [ ] 接口文档更新
EOF

步骤 7: 最终提交

git add doc/implementation/lsfx-update-report-*.md
git commit -m "docs(lsfx): 添加接口更新实施报告"
git log --oneline

验收标准

功能验收

  • 项目编译无错误
  • 应用启动成功
  • Swagger UI正常访问
  • 接口5、6已删除
  • 接口2、3、4、7的Response字段完整
  • 接口7使用新路径和新参数名

代码验收

  • 无残留的import语句
  • DTO类使用@Data注解
  • 字段类型正确Integer、String、BigDecimal等
  • 方法注释完整清晰

文档验收

  • 配置文件注释清晰
  • 实施报告完整
  • 提交信息规范

故障排查指南

问题1编译报错找不到类

原因: 残留的import语句 解决: 搜索并删除所有对GenerateReportRequest/Response和CheckReportStatusResponse的引用

问题2启动报错配置项不存在

原因: Client中仍然注入已删除的配置项 解决: 检查LsfxAnalysisClient.java删除generate-report和check-report-status的@Value注入

问题3Swagger UI不显示接口

原因: Controller方法签名错误 解决: 检查LsfxTestController.java确保所有方法都有@Operation注解

问题4接口调用返回字段为null

原因: DTO字段名与API返回不匹配 解决: 对比新文档响应示例,确保字段名完全一致(区分大小写)


参考资料

  • 新版接口文档:doc/对接流水分析/兰溪-流水分析对接-新版.md
  • 设计文档:docs/plans/2026-03-02-lsfx-integration-design.md
  • 若依框架规范:CLAUDE.md

计划完成日期: 2026-03-02 预计实施时间: 2-3小时 风险等级:涉及多个DTO重构