通过此接口异步调用订单状态回接API,返回订单充值信息
1、订单号可通过接口“suning.custom.virtual.confirm”获取;
2、请求参数苏宁订单号、苏宁订单行号、处理结果、商品信息快照、充值成功时间、卡号、密码、失败代码、失败原因
2、返回苏宁订单号、苏宁订单行号、处理结果、失败代码、失败原因
名称 | 类型 | 是否必须 | 示例值 | 描述 |
---|---|---|---|---|
appMethod | String | Y | suning.custom.category.query | 方法名 |
appRequestTime | String | Y | 2012-04-25 20:23:30 | 时间戳,格式为yyyy-MM-dd HH:mm:ss,例如:2012-04-25 20:23:30。API服务端允许客户端请求时间误差为10分钟。 |
format | String | N | XML | 默认xml,可指定格式为xml,json |
appKey | String | Y | b0c332a133c102765f39de********** | 分配给应用的访问令牌 |
versionNo | String | Y | v1.2 | API的版本,目前为v1.2版本 |
signInfo | String | Y | 460d7ff15b073e463125b4********** | appSecret,appMethod ,appRequestTime, appKey, versionNo, 请求报文base64加密后的数据顺序MD5(32位小写),其中appSecret为appKey对应的密钥 |
access_token | String | N | a1c5c62b08df3a3cbf7efd********** | 采用OAuth授权方式为必填参数 |
名称 | 类型 | 是否必须 | 示例值 | 描述 |
---|---|---|---|---|
orderCode | String | Y | 10000011 | 苏宁订单号 |
orderItemCode | String | Y | 00120485973301 | 苏宁订单行号 |
dealResult | String | Y | T | 处理结果(T-充值成功 F-充值失败 ) |
goodsSnap | String | N | URL | 商品信息快照 |
successTime | String | N | 2018-01-01 00:01:01 | 充值成功时间 |
failedCode | String | N | FAIL0 | 失败代码 |
cardList | String | N | ||
cardCode | String | N | 1234567899 | 充值卡号 |
cardSec | String | N | I001XB999 | 充值密码 |
failedReason | String | N | 卡号密码不正确 | 失败原因 |
codeList | String | N | ||
veCode | String | N | 1223344455 | 验证码 |
名称 | 类型 | 示例值 | 描述 |
---|---|---|---|
orderCode | String | 10000011 | 苏宁订单号 |
orderItemCode | String | 00120485973301 | 苏宁订单行号 |
receiveFlag | String | Y | 处理结果(接收成功Y 失败N) |
<sn_request> <sn_body> <confirmVirtual> <cardList> <cardSec>I001XB999</cardSec> <cardCode>1234567899</cardCode> </cardList> <failedCode>FAIL0</failedCode> <successTime>2018-01-01 00:01:01 </successTime> <orderItemCode>00120485973301</orderItemCode> <orderCode>10000011</orderCode> <codeList> <veCode>1223344455</veCode> </codeList> <dealResult>T</dealResult> <failedReason>卡号密码不正确</failedReason> <goodsSnap>URL</goodsSnap> </confirmVirtual> </sn_body> </sn_request>
{ "sn_request": { "sn_body": { "confirmVirtual": { "cardList": [ { "cardSec": "I001XB999", "cardCode": "1234567899" } ], "failedCode": "FAIL0", "successTime": "2018-01-01 00:01:01 ", "orderItemCode": "00120485973301", "orderCode": "10000011", "codeList": [ { "veCode": "1223344455" } ], "dealResult": "T", "failedReason": "卡号密码不正确", "goodsSnap": "URL" } } } }
<sn_responseContent> <sn_body> <confirmVirtual> <receiveFlag>Y</receiveFlag> <orderItemCode>00120485973301</orderItemCode> <orderCode>10000011</orderCode> </confirmVirtual> </sn_body> </sn_responseContent>
{ "sn_responseContent": { "sn_body": { "confirmVirtual": { "receiveFlag": "Y", "orderItemCode": "00120485973301", "orderCode": "10000011" } } } }
异常码 | 错误描述 | 解决方案 |
---|---|---|
biz.custom.confirmvirtual.missing-parameter:* | 参数必填 | 请检查此参数的值,*号表示参数字段名 |
biz.custom.confirmvirtual.format-error:* | 参数格式错误 | 请检查此参数的值,*号表示参数字段名 |
biz.custom.confirmvirtual.length-overlong:* | 参数的值超过规定长度 | 请检查此参数的值,*号表示参数字段名 |
isp.sys.service.unavailable.moms | 服务不可用 | 请联系苏宁技术人员 |
biz.custom.confirmvirtual.invalid-biz:100 | 最多支持99个卡密 | 卡密数量请控制100以内 |
biz.custom.confirmvirtual.invalid-biz:101 | 卡密数量与购买数量不一致 | 请联系苏宁技术人员 |
biz.custom.confirmvirtual.invalid-biz:102 | 订单不存在 | 请确认订单是否存在 |
biz.custom.confirmvirtual.invalid-biz:103 | 订单不是虚拟充值订单 | 请确认订单是否是虚拟充值订单 |
biz.custom.confirmvirtual.invalid-biz:104 | 卡密数量不能为0 | 请确认卡密数量 |
biz.custom.confirmvirtual.invalid-biz:105 | 交易已关闭 | 请确认订单状态 |
biz.custom.confirmvirtual.invalid-biz:106 | 订单行项目为退款中的订单 | 请确认订单状态 |
biz.custom.confirmvirtual.invalid-biz:107 | 数字码长度超过限制 | 请确认数字码 |
biz.custom.confirmvirtual.invalid-biz:108 | 数字码不能包含中文 | 请确认数字码 |
biz.custom.confirmvirtual.invalid-biz:109 | 三方核销数字码数量与商品数据不一样 | 请确认数字码 |
biz.custom.confirmvirtual.invalid-biz:110 | 数字码不允许重复 | 请确认数字码 |
异常码 | 错误描述 | 解决方案 |
---|---|---|
sys.check.user-permission:inexistence | 访问令牌不存在 | 更换访问令牌 |
sys.check.user-permission:overdue | 访问令牌已过期 | 请使用刷新令牌刷新 |
sys.check.api-permission:inexistence | Api方法不存在 | 请参考帮助中心 |
sys.check.api-permission:overdue | Api方法已过期 | 请参考帮助中心 |
sys.check.method-permission:authority | 无权操作此api | 确认是否有访问该方法权限 |
sys.auth.vendor-request:errory | 无权操作此供应商 | 请确认供应商编码是否正确 |
sys.controller.api-request:limit | Api请求受控 | 超过请求次数 |
sys.check.app-time:error | 请求参数错误api请求时间误差大 | 参考帮助中心 |
sys.check.request-params:error | 请求报文结构错误 | 参考帮助中心、日期格式等 |
sys.check.starttime-format:error | 请求开始时间错误 | 参考帮助中心、日期格式等 |
biz.handler.data-get:success | 业务数据查询成功 | 无 |
biz.handler.data-get:fail | 业务数据查询失败 | 检查请求条件 |
biz.handler.data-get:no-result | 业务数据结果为空 | 无 |
sys.check.pageno-format:error | pageNo格式错误,只允许1到99999之间的整数 | 检查pageNo输入是否有误 |
sys.check.pagesize-format:error | pageSize格式错误,只允许1到50之间的整数(订单相关是1到100) | 检查pageSize输入是否有误 |
sys.check.page-param:error | pageNo或者pageSize不在要求范围内,pageNo只允许1到99999之间的整数,pageSize只允许1到50之间的整数(订单相关是1到100) | 检查pageNo和pageSize输入是否有误 |
sys.check.miss-time:starttime | 不存在开始时间(节点) | 检查输入 |
sys.check.miss-time:endtime | 不存在结束时间(节点) | 检查输入 |
sys.check.starttime-value:null | 开始时间为空(值) | 检查输入 |
sys.check.endtime-value:null | 结束时间为空(值) | 检查输入 |
sys.check.starttime-format:error | 校验开始时间不合法,格式yyyy-MM-dd HH:mm:ss | 检查时间格式 |
sys.check.endtime-format:error | 校验结束时间不合法,格式yyyy-MM-dd HH:mm:ss | 检查时间格式 |
sys.check.query-time:error | 开始时间是否小于结束时间 | 检查开始和结束时间大小 |
sys.check.query-time:outofrange | 时间查询是否超出指定范围 | 检查时间范围 |
sys.check.app-sign:null | 签名信息为空 | 检查签名信息 |
sys.check.app-sign:error | 签名信息错误 | 检查签名信息 |
sys.check.missing-parameter:apiversion | API版本号未指定 | 检查API版本号 |
sys.check.missing-parameter:appRequestTime | 请求时间丢失 | 检查请求时间 |
sys.check.missing-nestElement:sn_body | 缺少sn_body节点 | 检查sn_body是否存在 |
sys.check.user-permission:inexistence | 用户key不存在 | 检查用户key是否存在 |
biz.handler.batch-handler:no-support | 非查询类API不支持批量操作 | 检查API类型 |
biz.handler.request-message:error | 查询类API输入多个业务节点 | 检查业务节点 |
sys.check.header-param:null | header参数为空 | 请检查header参数 |
sys.controller.api-access:limit | 访问限制 | 无 |
sys.controller.api-frequency:limit | 访问频率限制 | 无 |
sys.error.network:failure | 网络异常 | 无 |
sys.error.network-status:? | 响应失败 ?为状态码 | 无 |
sys.check.snunionid.length.is.not:48 | 混淆会员编码长度不是48位 | 使用转换器转换混淆会员编码规定要求混淆会员编码48位 |