> Copyright © 2026 浙江商盟支付有限公司 (SUM PAYMENT SERVICES CO.,LTD). All rights reserved.
> 本 Skill 包含商盟收结汇4.0产品 SDK、证书及开发规范,仅供授权商户集成使用,禁止未经授权的传播或商用。
在现有 Java Spring Boot 项目中集成 Sumpay 收结汇4.0(跨境收结汇)产品。
触发条件:
/sumpay-fx-settle-4 触发
不触发条件:
执行本 Skill 前,商户需已获取:
| 准备项 | 说明 |
|--------|------|
| 商户号 (mer_no) | 商盟开户时由商务提供 |
| 应用ID (app_id) | 商盟技术支持提供 |
| 文档系统 Token | 格式:API-Doc:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx |
测试环境默认值:商户号 200104913781,应用ID s100000040,证书密码 sumpay。生产环境替换为真实值。
SDK、Demo、证书、在线接口文档均通过文档系统动态获取,详见 resource-download.md。
以下规则在整个 Skill 执行过程中必须遵守,违反将导致编译失败或运行时错误:
Request.setCertType("CERT") 处理签名类型,设在 bizRequest 上会导致 sign_type 参与签名,服务端返回 888888
888888
targetRequest.setFileParams() 传递
在线接口文档是对接的前置依赖。使用 AskUserQuestion 要求用户提供 Token:
用户提供 Token 后,按 resource-download.md 拉取目录树,识别各资源对应的 catalogId。
扫描当前工作目录,了解:项目结构、构建工具(Maven/Gradle)、Spring Boot 版本、现有配置格式、代码风格。
如果当前目录不是 Java 项目,使用 AskUserQuestion 确认目标项目路径。
向用户确认:商户号、App ID、目标环境、证书路径、证书密码、域名、需要接入的接口列表。
核心接口(默认全选):2.1 个人客户信息上传、2.3 企业客户信息上传、2.2 查询个人客户信息、2.4 查询企业客户信息、2.9 文件上传、2.10 文件查询、2.40 收款材料上送、2.41 收款材料异步通知、2.42 直接下发、2.43 直接下发查询、2.44 直接下发异步通知、2.45 收结汇4.0材料查询
可选接口:2.46 收结汇财务明细下载、2.29 下发电子回单下载
① 客户报备(2.1/2.3) → customer_no
② 客户查询(2.2/2.4) → 客户状态信息
③ 文件上传(2.9) → sumpay_batch_no
④ 文件查询(2.10) → 文件处理状态
⑤ 收款材料上送(2.40) ← 引用 customer_no + sumpay_batch_no
⑥ 直接下发(2.42) ← 引用 customer_no
⑦ 确认结果 ← 异步通知(2.44) + 主动查询(2.43)
⑧ 材料审核结果 ← 异步通知(2.41) + 主动查询(2.45)
⑨ 对账(2.46) — 每日财务明细下载
⑩ 电子回单(2.29) — 下发成功后下载回单
| 接口 | 前置依赖 | 产出数据 |
|------|----------|----------|
| 2.1/2.3 客户报备 | 无 | customer_no |
| 2.2/2.4 客户查询 | customer_no 或 mer_serial_no | 客户状态信息 |
| 2.9 文件上传 | 无 | sumpay_batch_no |
| 2.10 文件查询 | file_token | 文件处理状态 |
| 2.40 材料上送 | customer_no + sumpay_batch_no | 提交审核 |
| 2.41 材料通知 | — | 审核结果(异步回调) |
| 2.42 直接下发 | customer_no | trade_no |
| 2.43 下发查询 | order_no | 下发结果 |
| 2.44 下发通知 | — | 下发结果(异步回调) |
| 2.45 材料查询 | mer_serial_no | 审核结果 |
| 2.46 财务明细 | bill_date | 对账文件链接 |
| 2.29 电子回单 | trade_no | 回单下载链接 |
快速验证:查询类接口(2.2/2.4/2.10/2.43/2.45)无需前置数据,用不存在的单号查询,只要不是 888888 或 EG000001 就说明签名通信正常。
按 resource-download.md 下载 SDK 和 Demo,解压 SDK JAR 到项目 lib/,解压 Demo 到临时目录。集成到项目详见 sdk-integration.md。
详见 sdk-reference.md 中的「Demo 映射表」和「已验证接口模式」
代码生成前的强制性验证步骤。 具体流程:
Demo 已在第二步下载并解压到临时目录。每个接口都有对应的 Demo 文件(见 sdk-reference.md 的映射表)。读取 Demo 是获取正确调用模式(文件上传方式、subParams key、序列化行为)的唯一可靠来源。
对每个目标接口对应的 SDK Request 类执行 javap,提取所有实际存在的 setter 方法签名:
javap -p -cp lib/merchant-integration-api-core.jar {完整类路径}
同时反编译所有被 Demo 引用的 entity 类(如 CollectDetailFile)。
将以下三者交叉比对,生成每个接口的已验证方法清单:
⛔ 如果文档字段在 javap 中找不到对应 setter → 该字段不生成 setter 调用,记录到 TODO
⛔ 如果 Demo 的调用方式与文档不一致 → 以 Demo 为准
⛔ 如果 Demo 使用了 javap 中不存在的 entity 类 → 先 javap 该 entity 类确认
验证完成标志: 每个接口都有一个「已验证方法清单」,列明:哪些 setter 可以调用、哪些字段走 subParams、文件上传走 fileParams 还是 req.setFile()、响应外层 key(如 sumpay_distribute_response)和响应内层字段映射。清单作为第四步代码生成的唯一输入。
硬性门禁:必须完成第三步验证后才能生成代码。 每一个 setXxx() 调用都必须能追溯到 javap 输出和 Demo 源码。
在现有项目包结构下生成收结汇模块代码(config/client/model/service/exception),遵循项目已有的包命名规范和代码风格。
按 resource-download.md 下载测试证书到 src/main/resources/cert/。
编译与测试详见 testing-and-deployment.md
硬性要求:为本次接入的所有接口生成单元测试,且测试必须通过。
Step 1: 建议用户执行 mvn clean compile → 编译通过
Step 2: 为所有接口生成单元测试 → 查询类启用,写入类/通知类 @Disabled
Step 3: 建议用户执行 mvn test → 查询类测试必须全部通过(硬性门禁)
Step 4: 向用户报告完整测试结果 → 列出每个测试的状态和响应码
查询类(6 个测试)不通过 = 集成失败,必须排查后重跑。写入类/通知类生成框架代码标注 TODO,提醒用户替换数据后启用。
详见 sdk-reference.md — 环境规格、签名机制、SDK 类路径、service 枚举、错误排查。
共 5 个版本