必须在订单日志中显式固化payment_channel字段,于订单创建和支付回调双节点记录,使用统一枚举值并设为索引字段,禁止缩写、推导或嵌套存储。
订单日志里漏记 payment_channel,等于埋了个定时炸弹——后续对账、渠道效果分析、甚至风控排查都可能卡壳。必须在日志写入时就固化这个字段,不能靠事后补全或靠订单表反查。
payment_channel 字段别依赖“订单表里有,日志里不存也行”。订单状态会变,支付渠道却只在创建/支付那一刻确定。日志是不可变事实快照,payment_channel 必须作为独立字段写入,而不是塞进模糊的 remark 或 extra 里。
payment_channel 值应来自支付请求源头(如前端传参、网关回调参数),不是从用户 ID 或订单类型推导alipay_app、wechat_jsapi、unionpay_h5、bank_transfer,避免用 ali / wx 这类缩写{"order_id":"ORD123","payment_channel":"alipay_app","status":"paid","created_at":"2025-06-15 10:22:33"}只在回调里记?错。用户可能下单后放弃支付,或者支付成功但回调丢失。必须双保险:
create_order 接口):只要用户选了支付方式,就立刻记一条 status=created 的日志,带 payment_channel
notify 接口):无论成功失败,都追加日志,复用原 payment_channel,不重新取值log_type 分类(如 order_create / payment_notify),方便按渠道聚合查询$_POST 或 $_GET 直接取渠道值用户可控参数不能直接入库或入日志。微信回调里 trade_type 是可信的,但前端提交的 channel 参数可能被篡改。
bank_transfer)service 或 pay_method,微信用 trade_type,并做白名单校验if (!in_array($channel, ['alipay_app', 'wechat_jsapi', 'unionpay_h5'])) { log_error("invalid payment_channel: $channel"); }payment_channel 做索引字段如果日志存在 MySQL 或 Elasticsearch 中,别等要用时才发现查不动。提前把 payment_channel 设为索引字段:
payment_channel 加普通索引,尤其当单日日志量 >10 万条时"payment_channel": {"type": "keyword"},不用 text
SELECT COUNT(*) FROM order_log WHERE payment_channel = 'wechat_jsapi' AND status = 'failed';
最常被忽略的是
:日志里写了 payment_channel,但没统一命名规范,导致有的写 wxpay,有的写 wechat_pay,有的还带大小写混用。查的时候得先去 dedup,不如一开始就 enforce 枚举。