8.8 KiB
8.8 KiB
手机号码功能详细排查指南
✅ 已确认信息
- 表头列名:
下单电话(严格匹配) - 数据字段:
status(订单的status字段存储手机号码) - 示例数据:
17703916233
🔍 增强的日志输出
现在代码中已经添加了详细的DEBUG和INFO日志,重新编译部署后,您会看到以下完整的日志链路:
1️⃣ 表头列识别日志
开始识别表头列,共 26 列
列 0 内容: [日期]
列 1 内容: [公司]
列 2 内容: [单号]
✓ 识别到 '单号' 列:第 3 列(索引2)
列 3 内容: [型号]
列 4 内容: [数量]
列 5 内容: [姓名]
列 6 内容: [下单电话]
✓ 识别到 '下单电话' 列:第 7 列(索引6),列名: [下单电话]
...
表头列识别完成
列位置识别完成 - 单号: 2, 物流单号: 12, 是否安排: null, 标记: 14, 下单电话: 6
✅ 关键检查点:
- 必须看到
✓ 识别到 '下单电话' 列这一行 - 最后一行
下单电话: 6不能是null
2️⃣ 手机号提取日志
准备从status字段提取手机号 - 单号: JY202511061595, status内容: [17703916233]
原始文本: [17703916233]
清理后文本: [17703916233]
成功提取手机号码: [17703916233] <- 原文本: [17703916233]
✓ 从status字段提取手机号码 - 单号: JY202511061595, status: [17703916233], 手机号: 17703916233
✅ 关键检查点:
- 必须看到
成功提取手机号码这一行 - status内容不能为空
3️⃣ 准备写入日志
✓ 准备写入手机号码 - 单号: JY202511061595, 手机号: 17703916233, 行: 2575, 列: 6
4️⃣ batchUpdate请求体日志
批量更新表格 - 请求体: {
"requests":[
{"updateRangeRequest":{"sheetId":"BB08J2","gridData":{"startRow":2574,"startColumn":12,
"rows":[{"values":[{"cellValue":{"link":{"url":"https://3.cn/xxx","text":"https://3.cn/xxx"}}}]}]}}},
{"updateRangeRequest":{"sheetId":"BB08J2","gridData":{"startRow":2574,"startColumn":6, <-- 手机号列
"rows":[{"values":[{"cellValue":{"text":"17703916233"}}]}]}}},
{"updateRangeRequest":{"sheetId":"BB08J2","gridData":{"startRow":2574,"startColumn":14,
"rows":[{"values":[{"cellValue":{"text":"251106"}}]}]}}}
]
}
✅ 关键检查点:
requests数组应该有 3个元素(物流、手机号、标记)- 其中一个
startColumn应该是 6(如果下单电话在第7列)
5️⃣ 写入成功日志
✓ 写入成功 - 行: 2575, 单号: JY202511061595, 物流链接: https://3.cn/xxx, 手机号: 17703916233
🎯 部署和测试步骤
步骤1: 重新编译后端
cd d:\code\RuoYi-Vue-master\ruoyi-java
mvn clean package -DskipTests
步骤2: 重启后端服务
确保服务完全重启,加载了新的代码。
步骤3: 启用DEBUG日志(可选,推荐)
如果想看到更详细的日志,修改 application.yml 或 logback.xml:
logging:
level:
com.ruoyi.web.controller.jarvis.TencentDocController: DEBUG
步骤4: 执行批量同步
- 打开订单列表页面
- 点击"批量同步物流"按钮
- 确认同步
步骤5: 查看日志
查看后端日志,按照上面的 5️⃣ 个关键节点逐一检查。
🐛 问题排查流程
问题A: 没有识别到"下单电话"列
症状:
列位置识别完成 - 单号: 2, 物流单号: 12, 是否安排: null, 标记: 14, 下单电话: null
排查:
- 查看前面的
列 X 内容: [XXX]日志,找到所有列名 - 确认是否真的有一列叫 "下单电话"
- 检查列名是否有额外的空格或特殊字符
- 如果列名是 "电话" 或 "手机",也应该能识别
解决:
- 如果列名不匹配,在腾讯文档中将该列重命名为 "下单电话"
- 或者修改代码,添加更多匹配规则
问题B: 识别到列但没有提取到手机号
症状:
✓ 识别到 '下单电话' 列:第 7 列(索引6),列名: [下单电话]
...
phoneColumn为null,跳过手机号提取 - 单号: JY202511061595
这个不应该发生! 如果识别到了列,phoneColumn 就不应该是null。
排查:
- 检查是否有异常日志
- 可能是代码逻辑问题
问题C: status字段为空或不包含手机号
症状:
准备从status字段提取手机号 - 单号: JY202511061595, status内容: []
或
准备从status字段提取手机号 - 单号: JY202511061595, status内容: [其他内容,没有手机号]
未找到匹配的手机号码,文本: [其他内容]
排查:
- 确认订单的status字段确实存储了手机号码
- 检查数据库中该订单的status值
- 可能某些订单的status字段不包含手机号
解决:
- 确保所有需要同步的订单,其status字段都包含11位手机号码
- 如果status字段用于其他用途,可能需要调整数据结构
问题D: 提取成功但请求体中没有手机号字段
症状:
✓ 从status字段提取手机号码 - 单号: JY202511061595, status: [17703916233], 手机号: 17703916233
...
批量更新表格 - 请求体: {"requests":[...]} <-- 只有2个updateRangeRequest
排查:
- 查看
✓ 准备写入手机号码日志是否存在 - 检查代码逻辑,update对象是否正确构建
问题E: 写入请求发送但腾讯文档没有显示
症状: 日志显示写入成功,但腾讯文档中"下单电话"列仍然为空。
排查:
- 检查API响应,是否真的返回
updatedCells: 1 - 刷新腾讯文档页面
- 检查列索引是否正确(可能写到了其他列)
- 检查该列是否有格式限制或保护
📊 完整日志示例(成功场景)
22:03:29.150 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - 开始读取表头 - 行号: 2, range: A2:Z2
22:03:29.259 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - 开始识别表头列,共 26 列
22:03:29.259 [http-nio-30313-exec-10] DEBUG c.r.w.c.j.TencentDocController - 列 0 内容: [日期]
22:03:29.259 [http-nio-30313-exec-10] DEBUG c.r.w.c.j.TencentDocController - 列 1 内容: [公司]
22:03:29.259 [http-nio-30313-exec-10] DEBUG c.r.w.c.j.TencentDocController - 列 2 内容: [单号]
22:03:29.259 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - ✓ 识别到 '单号' 列:第 3 列(索引2)
22:03:29.259 [http-nio-30313-exec-10] DEBUG c.r.w.c.j.TencentDocController - 列 6 内容: [下单电话]
22:03:29.259 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - ✓ 识别到 '下单电话' 列:第 7 列(索引6),列名: [下单电话]
22:03:29.259 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - 表头列识别完成
22:03:29.259 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - 列位置识别完成 - 单号: 2, 物流单号: 12, 是否安排: null, 标记: 14, 下单电话: 6
... (读取数据行) ...
22:03:29.500 [http-nio-30313-exec-10] DEBUG c.r.w.c.j.TencentDocController - 准备从status字段提取手机号 - 单号: JY202511061595, status内容: [17703916233]
22:03:29.500 [http-nio-30313-exec-10] DEBUG c.r.w.c.j.TencentDocController - 原始文本: [17703916233]
22:03:29.500 [http-nio-30313-exec-10] DEBUG c.r.w.c.j.TencentDocController - 清理后文本: [17703916233]
22:03:29.500 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - 成功提取手机号码: [17703916233] <- 原文本: [17703916233]
22:03:29.500 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - ✓ 从status字段提取手机号码 - 单号: JY202511061595, status: [17703916233], 手机号: 17703916233
22:03:29.500 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - 找到订单物流链接 - 单号: JY202511061595, 物流链接: https://3.cn/xxx, 手机号: 17703916233, 行号: 2575, 已推送: 否
... (批量写入) ...
22:03:29.700 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - ✓ 准备写入手机号码 - 单号: JY202511061595, 手机号: 17703916233, 行: 2575, 列: 6
22:03:29.700 [http-nio-30313-exec-10] DEBUG c.r.j.u.TencentDocApiUtil - 批量更新表格 - 请求体: {"requests":[...3个updateRangeRequest...]}
22:03:30.284 [http-nio-30313-exec-10] INFO c.r.w.c.j.TencentDocController - ✓ 写入成功 - 行: 2575, 单号: JY202511061595, 物流链接: https://3.cn/xxx, 手机号: 17703916233
🎯 下一步行动
- 重新编译部署
- 执行一次批量同步
- 复制完整日志(从"开始识别表头列"到"写入成功"的所有日志)
- 提供给我分析
如果还有问题,请提供:
- ✅ 完整的表头识别日志(包括所有
列 X 内容的DEBUG日志) - ✅ 手机号提取相关的所有日志
- ✅ batchUpdate请求体的完整JSON
- ✅ 腾讯文档表头的截图
最后更新: 2025-11-06 22:30
版本: v2.0 - 增强日志版