新增个人模型输出灰黑名单客户字段

This commit is contained in:
wkc
2026-04-27 15:44:11 +08:00
parent 571f7bc075
commit 886cba6b3d
11 changed files with 78 additions and 0 deletions

View File

@@ -284,6 +284,7 @@ GET /loanPricing/workflow/20250119143025123
"idType": "身份证",
"idNum": "330102199001011234",
"baseLoanRate": "3.45",
"greyBlackCust": "1",
"isFirstLoan": "true",
"faithDay": "365",
"custAge": "35",

View File

@@ -0,0 +1,54 @@
# 2026-04-27 个人模型输出灰黑名单客户字段实施记录
## 修改内容
- 后端个人模型输出实体 `ModelRetailOutputFields` 新增 `greyBlackCust` 字段,承接个人模型返回的 `0/1` 输出值。
- 个人模型 mock 返回文件 `retail_output.json` 新增 `greyBlackCust: "1"`,用于本地模型调用链路验证。
- `model_retail_output_fields` 表结构新增 `grey_black_cust` 字段,并补充增量迁移脚本 `sql/add_model_retail_grey_black_cust_20260427.sql`
- 前端模型输出组件在个人客户“基本信息”分组中展示“灰黑名单客户”,直接展示后端返回值 `0/1`
- 接口文档示例补充 `greyBlackCust` 返回字段。
## 涉及文件
- `ruoyi-loan-pricing/src/main/java/com/ruoyi/loanpricing/domain/entity/ModelRetailOutputFields.java`
- `ruoyi-loan-pricing/src/main/resources/data/retail_output.json`
- `ruoyi-loan-pricing/src/test/java/com/ruoyi/loanpricing/domain/entity/ModelRetailOutputFieldsTest.java`
- `ruoyi-ui/src/views/loanPricing/workflow/components/ModelOutputDisplay.vue`
- `ruoyi-ui/tests/retail-display-fields.test.js`
- `sql/model_retail.sql`
- `sql/loan_pricing_schema_20260328.sql`
- `sql/loan_pricing_prod_init_20260331.sql`
- `sql/add_model_retail_grey_black_cust_20260427.sql`
- `doc/api/loan-pricing-workflow-api.md`
## 数据库变更
- 已在开发库 `loan-pricing.model_retail_output_fields` 执行新增列:
```sql
ALTER TABLE model_retail_output_fields
ADD COLUMN grey_black_cust varchar(100) DEFAULT '' COMMENT '灰黑名单客户' AFTER base_loan_rate;
```
- 回查结果确认 `grey_black_cust` 字段存在。
## 验证记录
- `mvn -pl ruoyi-loan-pricing -Dtest=ModelRetailOutputFieldsTest,LoanPricingModelServiceTest -Dsurefire.failIfNoSpecifiedTests=false test`
- 通过,确认实体字段存在,个人/企业模型调用基础链路未回归。
- `zsh -lic 'nvm use 14 >/dev/null && npm --prefix ruoyi-ui run test:retail-display-fields && npm --prefix ruoyi-ui run test:model-output-flat-display'`
- 通过,确认前端包含 `retailOutput.greyBlackCust` 且字段位于个人模型输出“基本信息”分组。
- `zsh -lic 'nvm use 14 >/dev/null && npm --prefix ruoyi-ui run build:prod'`
- 通过,存在既有包体积 warning无编译错误。
- 后端真实接口验证:
- 重启后端后调用个人流程创建接口,业务流水号 `20260427153305173`
- 调用详情接口返回 `modelRetailOutputFields.greyBlackCust = 1`
- 数据库联表回查 `model_retail_output_fields.grey_black_cust = 1`
- browser-use 真实页面验证:
- 使用前端开发服务 `http://127.0.0.1:63311/` 打开真实流程详情页。
- 页面 `模型输出 > 基本信息` 中可见“灰黑名单客户”,展示值为 `1`
- 测试结束后已停止本次启动的后端 `63310` 与前端 `63311` 进程,并回查端口不再监听。
## 备注
- 组合执行 `LoanPricingModelServicePersonalParamsTest` 时,当前本机 JDK 21 下 Mockito inline ByteBuddy 自附加失败;该失败与本次字段改动无关。已单独执行本次直接相关的非 Mockito 失败用例并通过。

View File

@@ -41,6 +41,9 @@ public class ModelRetailOutputFields {
// 基准利率
private String baseLoanRate;
// 灰黑名单客户
private String greyBlackCust;
// 我行首贷客户
private String isFirstLoan;

View File

@@ -10,6 +10,7 @@
"idType": "身份证",
"idNum": "330106199001011234",
"baseLoanRate": "4.35",
"greyBlackCust": "1",
"isFirstLoan": "是",
"faithDay": "365",
"custAge": "36",

View File

@@ -22,5 +22,6 @@ class ModelRetailOutputFieldsTest
assertTrue(fieldNames.contains("smoothRange"), "缺少字段 smoothRange");
assertTrue(fieldNames.contains("finalCalculateRate"), "缺少字段 finalCalculateRate");
assertTrue(fieldNames.contains("referenceRate"), "缺少字段 referenceRate");
assertTrue(fieldNames.contains("greyBlackCust"), "缺少字段 greyBlackCust");
}
}

View File

@@ -14,6 +14,7 @@
<el-descriptions-item label="证件类型">{{ retailOutput.idType || '-' }}</el-descriptions-item>
<el-descriptions-item label="证件号码">{{ retailOutput.idNum || '-' }}</el-descriptions-item>
<el-descriptions-item label="基准利率"><span class="rate-value">{{ retailOutput.baseLoanRate || '-' }}</span> %</el-descriptions-item>
<el-descriptions-item label="灰黑名单客户">{{ formatOutputValue(retailOutput.greyBlackCust) }}</el-descriptions-item>
</el-descriptions>
</div>
@@ -236,6 +237,10 @@ export default {
if (value === 'consumer') return '消费贷款'
if (value === 'business') return '经营贷款'
return value || '-'
},
formatOutputValue(value) {
if (value === 0) return '0'
return value || '-'
}
}
}

View File

@@ -15,6 +15,7 @@ assert(
)
const requiredRetailFields = [
'retailOutput.greyBlackCust',
'retailOutput.loanRateHistory',
'retailOutput.minRateProduct',
'retailOutput.smoothRange',
@@ -26,4 +27,10 @@ requiredRetailFields.forEach((field) => {
assert(modelOutput.includes(field), `模型输出缺少字段展示: ${field}`)
})
assert(
modelOutput.indexOf('label="灰黑名单客户"') > modelOutput.indexOf('<h4 class="section-title">基本信息</h4>')
&& modelOutput.indexOf('label="灰黑名单客户"') < modelOutput.indexOf('<h4 class="section-title">测算结果</h4>'),
'灰黑名单客户未展示在个人模型输出基础信息中'
)
console.log('retail display fields assertions passed')

View File

@@ -0,0 +1,2 @@
ALTER TABLE `model_retail_output_fields`
ADD COLUMN `grey_black_cust` varchar(100) DEFAULT '' COMMENT '灰黑名单客户' AFTER `base_loan_rate`;

View File

@@ -873,6 +873,7 @@ CREATE TABLE `model_retail_output_fields` (
`id_type` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '证件类型',
`id_num` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '证件号码',
`base_loan_rate` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '基准利率',
`grey_black_cust` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '灰黑名单客户',
`is_first_loan` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '我行首贷客户',
`faith_day` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '用信天数',
`cust_age` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '客户年龄',

View File

@@ -455,6 +455,7 @@ CREATE TABLE `model_retail_output_fields` (
`id_type` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '证件类型',
`id_num` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '证件号码',
`base_loan_rate` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '基准利率',
`grey_black_cust` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '灰黑名单客户',
`is_first_loan` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '我行首贷客户',
`faith_day` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '用信天数',
`cust_age` varchar(100) COLLATE utf8mb4_general_ci DEFAULT '' COMMENT '客户年龄',

View File

@@ -20,6 +20,8 @@ CREATE TABLE IF NOT EXISTS model_retail_output_fields (
id_num VARCHAR(100) DEFAULT '' COMMENT '证件号码',
-- 基准利率百分比如4.35
base_loan_rate VARCHAR(100) DEFAULT '' COMMENT '基准利率',
-- 灰黑名单客户0/1
grey_black_cust VARCHAR(100) DEFAULT '' COMMENT '灰黑名单客户',
-- 我行首贷客户(是/否)
is_first_loan VARCHAR(100) DEFAULT '' COMMENT '我行首贷客户',
-- 用信天数