易购上的C店订单开完票后,C店商户可调用此接口查询开票接口,该接口只查易购上的C店订单
名称 | 类型 | 是否必须 | 示例值 | 描述 |
---|---|---|---|---|
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授权方式为必填参数 |
名称 | 类型 | 是否必须 | 示例值 | 描述 |
---|---|---|---|---|
storage | String | N | ||
billNo | String | Y | 取单号的值(订单维度),例如:32281421244 | 业务单号 |
billType | String | Y | 01:OMS单号 02:OMS行号 03:B2C单号 04:B2C行号 返回报文时,返回对应行号 | 业务单号类型 |
saleTaxNo | String | N | 91320106773973920L | 销方税号 |
saleOrg | String | Y | 举例:70066253 | 商户编码 |
名称 | 类型 | 示例值 | 描述 |
---|---|---|---|
returnCode | String | 0000 | 查询成功与否标识,0000-成功,9999-失败 |
returnMsg | String | 调用失败 | 查询成功与否描述,如查询失败,查询成功与否标识返回9999时,返回报错信息 |
retrunInv | String | ||
saleOrg | String | 70066253 | 商户编码 |
saleTaxNo | String | 111122223333444455 | 销方税号 |
orderNo | String | 123456 | 业务单号,根据业务单号类型billType返回 billType为01时,返回OMS单号 billType为03时,返回B2C单号 |
orderItem | String | ||
orderItemId | String | 12345678 | 订单行号 |
invItems | String | ||
invoiceFlag | String | 04 | 发票标识,订单开具发票的类型标识 枚举值:01-增值税专用发票,02-增值税普通发票,04-电子发票 |
invoiceType | String | 1 | 发票类型,1-蓝票、-1-红票 |
invoiceCode | String | 032001700211 | 发票代码 |
invoiceNum | String | 88093702 | 发票号码 |
invoiceAmount | String | 100 | 开票金额 |
invoiceNoTaxAmount | String | 90 | 不含税金额 |
invoiceDate | String | 2019-11-11 | 开票日期,格式:YYYY-MM-DD |
invoiceSecurityCode | String | 59888 37763 38108 76652 | 发票校验码 |
oldInvoiceCode | String | 032001700211 | 原发票代码,发票类型为:-1时,且发票类型是04电子发票时,传值 |
oldInvoiceNum | String | 88093701 | 原发票号码,发票类型为:-1时,且发票类型是04电子发票时,传值 |
logisticsOrderId | String | 1111111111 | 物流单号,纸质发票存在物流单号 |
logisticsComp | String | 苏宁 | 物流公司,纸质发票存在物流公司 |
invoiceStatus | String | 2 | 发票开具状态,0-无发票 2-正常 |
invoicePdfUrl | String | www.suning.com | 发票PDF路径,发票文件url地址 |
<sn_request> <sn_body> <queryStorage> <storage> <saleTaxNo>91320106773973920L</saleTaxNo> <billType>01:OMS单号 02:OMS行号 03:B2C单号 04:B2C行号 返回报文时,返回对应行号</billType> <billNo>取单号的值(订单维度),例如:32281421244</billNo> <saleOrg>举例:70066253</saleOrg> </storage> </queryStorage> </sn_body> </sn_request>
{ "sn_request": { "sn_body": { "queryStorage": { "storage": [ { "saleTaxNo": "91320106773973920L", "billType": "01:OMS单号 02:OMS行号 03:B2C单号 04:B2C行号 返回报文时,返回对应行号", "billNo": "取单号的值(订单维度),例如:32281421244", "saleOrg": "举例:70066253" } ] } } } }
<sn_responseContent> <sn_body> <queryStorage> <returnCode>0000</returnCode> <returnMsg>调用失败</returnMsg> <retrunInv> <saleTaxNo>111122223333444455</saleTaxNo> <orderNo>123456</orderNo> <orderItem> <invItems> <invoiceFlag>04</invoiceFlag> <logisticsOrderId>1111111111</logisticsOrderId> <oldInvoiceCode>032001700211</oldInvoiceCode> <invoiceAmount>100</invoiceAmount> <logisticsComp>苏宁</logisticsComp> <invoiceDate>2019-11-11</invoiceDate> <invoiceCode>032001700211</invoiceCode> <invoiceNum>88093702</invoiceNum> <invoicePdfUrl>www.suning.com</invoicePdfUrl> <invoiceNoTaxAmount>90</invoiceNoTaxAmount> <invoiceSecurityCode>59888 37763 38108 76652</invoiceSecurityCode> <invoiceType>1</invoiceType> <invoiceStatus>2</invoiceStatus> <oldInvoiceNum>88093701</oldInvoiceNum> </invItems> <orderItemId>12345678</orderItemId> </orderItem> <saleOrg>70066253</saleOrg> </retrunInv> </queryStorage> </sn_body> </sn_responseContent>
{ "sn_responseContent": { "sn_body": { "queryStorage": { "returnCode": "0000", "returnMsg": "调用失败", "retrunInv": [ { "saleTaxNo": "111122223333444455", "orderNo": "123456", "orderItem": [ { "invItems": [ { "invoiceFlag": "04", "logisticsOrderId": "1111111111", "oldInvoiceCode": "032001700211", "invoiceAmount": "100", "logisticsComp": "苏宁", "invoiceDate": "2019-11-11", "invoiceCode": "032001700211", "invoiceNum": "88093702", "invoicePdfUrl": "www.suning.com", "invoiceNoTaxAmount": "90", "invoiceSecurityCode": "59888 37763 38108 76652", "invoiceType": "1", "invoiceStatus": "2", "oldInvoiceNum": "88093701" } ], "orderItemId": "12345678" } ], "saleOrg": "70066253" } ] } } } }
异常码 | 错误描述 | 解决方案 |
---|---|---|
biz.custom.querystorage.missing-parameter:* | 参数必填 | 请检查此参数的值,*号表示参数字段名 |
biz.custom.querystorage.length-overlong:* | 参数的值超过规定长度 | 请检查此参数的值,*号表示参数字段名 |
biz.handler.data-get:no-result | 查询没结果 | 请检查查询参数 |
isp.sys.service.unavailable.iips | 服务不可用 | 请联系苏宁技术人员 |
异常码 | 错误描述 | 解决方案 |
---|---|---|
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位 |