調(diào)用【將電子發(fā)票插入微信用戶卡包】接口之前,需要先調(diào)用本接口上傳電子發(fā)票文件,獲取文件ID。上傳的發(fā)票文件會在三天后過期,因此上傳后請盡快調(diào)用【將電子發(fā)票插入微信用戶卡包】接口執(zhí)行插入微信用戶卡包的操作。
# 接口說明
# 字段說明
# 請求參數(shù)
- file 必填 object電子發(fā)票文件二進制數(shù)據(jù)流,只支持PDF和OFD格式,文件大小不能超過2M。需要在請求body中通過表單提交的方式上傳此二進制內(nèi)容。
- meta 必填 object電子發(fā)票文件元信息
- 屬性
# 應(yīng)答字段
- fapiao_media_id 必填 string(128)上傳的電子發(fā)票文件對應(yīng)的ID,該文件ID三天內(nèi)有效。用于【將電子發(fā)票插入微信用戶卡包】接口。
# 文件上傳步驟
1.創(chuàng)建一個POST的方法請求/upload URI:
例如: POST https://api.mch.weixin.qq.com/new-tax-control-fapiao/fapiao-applications/upload-fapiao-file (opens new window) HTTP/1.1
2.將文件的數(shù)據(jù)添加到請求主體:
2.1 文本文件file參數(shù)的獲取方式說明:
文本文件二進制內(nèi)容,放在請求HTTP的body中。
2.2 電子發(fā)票文件元信息meta參數(shù)的獲取方式說明: 電子發(fā)票文件元信息,使用json表示,包含四個對象:sub_mchid、file_type、digest_algorithm、digest。
sub_mchid參數(shù)獲取方式說明: 微信支付分配的子商戶號,服務(wù)商模式下必傳
file_type參數(shù)獲取方式說明: 發(fā)票文件的類型為PDF - PDF文件類型,PDF文件類型
digest_algorithm參數(shù)獲取方式說明: 文件摘要算法,SM3 - 國密SM3算法,國密SM3摘要算法
digest參數(shù)獲取方式說明: 根據(jù)文件摘要算法對電子發(fā)票文件二進制內(nèi)容計算出的文件摘要,結(jié)果為16進制編碼
2.3 簽名計算說明:
參與簽名計算的請求主體為meta的json串:
1{ "file_type": "PDF","digest": "addca90a6a290b9642dbaccffdf01e8c22aa348940b2e96754169ba08c19e5db", "digest_algorithm": "SM3" }
# 請求示例
1{ 2 "file": { 3 }, 4 "meta": { 5 "digest": "addca90a6a290b9642dbaccffdf01e8c22aa348940b2e96754169ba08c19e5db", 6 "digest_algorithm": "SM3", 7 "file_type": "PDF", 8 "sub_mchid": "1900000109" 9 } 10}
# 應(yīng)答示例
1{2 "fapiao_media_id": "ASNFZ4mrze/+3LqYdlQyEA=="3}
待簽名串示例:
1POST2/v3/new-tax-control-fapiao/fapiao-applications/upload-fapiao-file31566987169 //時間戳412ced2db6f0193dda91ba86224ea1cd8 //隨機數(shù)5{ "file_type": "PDF","digest": "addca90a6a290b9642dbaccffdf01e8c22aa348940b2e96754169ba08c19e5db", "digest_algorithm": "SM3" }
添加HTTP頭:
1Content-Type:multipart/form-data.設(shè)置為要上載的對象的MIME媒體類型。2Authorization: WECHATPAY2-SHA256-RSA2048 mchid="1900231671",3nonce_str="PCHK6HSOEDTACETP6P3AL7DWPHTBKIAT",timestamp="1567067659",4serial_no="1FB89742D19F2BD30B69948D16DECA0FCB4481EB",5signature="PB6M7+3JL7TSCl5zqD1sdWVypOIEQsD4dgOU+vPiVM6GMRo2qYSWKf8u46i9ZJFhyZTBdZ7SFR+BjDZh6689hFgN8LZL+QWTvq3cse/FEUFYyOLN7L/2IZX4GA4cWInuJ2MpOhZRMpm+emrcn42gTMKAPNQ7dBLO7ux6MoSuQp697PW+p1ogmkER68exTVUXYqA5P3vITlWNr++RDy2+ExvB7qVISOKW0vBkxUxN9e7hwUbDwGln170ZXomoO1KpQSbw3f1u8WUCx/IlWJhJIun7rUMtVT+kfijNUqcILtSfE4hWKKVaZn9j5CX8M7aKbbDOFy3SvbSJ3WQgRnRbgog5w=="9Content-Type: multipart/form-data;boundary=boundary
添加body:
1// 以下為body的內(nèi)容2--boundary // boundary為商戶自定義的一個字符串3Content-Disposition: form-data; name="meta";4Content-Type: application/json5//此處必須有一個空行6{ "file_type": "PDF","digest": "addca90a6a290b9642dbaccffdf01e8c22aa348940b2e96754169ba08c19e5db", "digest_algorithm": "SM3" }7--boundary8Content-Disposition: form-data; name="file"; 9Content-Type: pdf/plain10//此處必須有一個空行11--boundary--
說明:請求包體每行結(jié)尾都需要包含\r\n(空行也需要)。
發(fā)送請求:
1POST /v3/new-tax-control-fapiao/fapiao-applications/upload-fapiao-file HTTP/1.12Host: api.mch.weixin.qq.com3Authorization: WECHATPAY2-SHA256-RSA2048 4mchid="1900231671",nonce_str="PCHK6HSOEDTACETP6P3AL7DWPHTBKIAT",5timestamp="1567067659",6serial_no="1FB89742D19F2BD30B69948D16DECA0FCB4481EB",7signature="PB6M7+3JL7TSCl5zqD1sdWVypOIEQsD4dgOU+vPiVM6GMRo2qYSWKf8u46i9ZJFhyZTBdZ78SFR+BjDZh689hFgN8LZL+QWTvq3cse/FEUFYyOLN7L/2IZX4GA4cWInuJ2MpOhZRMpm+emrcn42gTMKAPN9Q7dBLO7ux6MoSuQp69PW+p1ogmkER68exTVUXYqA5P3vITlWNr++RDy2+ExvB7qVISOKW0vBkxUxN9e107hwUbDwGln170ZXomoO1KpQSbw3f1uWUCx/IlWJhJIun7rUMtVT+kfijNUqcILtSfE4hWKKVaZn9j5CX8M117aKbbDOFy3SvbSJ3WQgRnRbgog5w=="12Content-Type: multipart/form-data;boundary=boundary1314--boundary 15Content-Disposition: form-data; name="meta";16Content-Type: application/json1718{ "file_type": "PDF","digest": "addca90a6a290b9642dbaccffdf01e8c22aa348940b2e96754169ba08c19e5db", "digest_algorithm": "SM3" }19--boundary20Content-Disposition: form-data; name="file"; 21Content-Type: pdf/plain2223--boundary--
# 錯誤碼
# 公共錯誤碼
狀態(tài)碼 | 錯誤碼 | 描述 | 解決方案 |
---|---|---|---|
400 | PARAM_ERROR | 參數(shù)錯誤 | 請根據(jù)錯誤提示正確傳入?yún)?shù) |
400 | INVALID_REQUEST | HTTP 請求不符合微信支付 APIv3 接口規(guī)則 | 請參閱 接口規(guī)則 |
401 | SIGN_ERROR | 驗證不通過 | 請參閱 簽名常見問題 |
500 | SYSTEM_ERROR | 系統(tǒng)異常,請稍后重試 | 請稍后重試 |
# 業(yè)務(wù)錯誤碼
狀態(tài)碼 | 錯誤碼 | 描述 | 解決方案 |
---|---|---|---|
429 | FREQUENCY_LIMITED | 頻率超限 | 請降低請求接口頻率 |
400 | PARAM_ERROR | 電子發(fā)票文件超過尺寸限制 | 請上傳2M以內(nèi)的電子發(fā)票文件 |
400 | INVALID_REQUEST | 請求參數(shù)符合參數(shù)格式,但不符合業(yè)務(wù)規(guī)則 | 請使用正確的參數(shù)重新調(diào)用 |
400 | INVALID_REQUEST | 電子發(fā)票文件與元信息中的摘要不匹配 | 請使用匹配的電子發(fā)票文件和摘要 |
401 | SIGN_ERROR | 簽名錯誤或簽名信息不完整 | 請檢查簽名參數(shù)和方法是否都符合簽名算法要求 |
403 | NO_AUTH | 商戶無權(quán)限 | 請檢查是否已經(jīng)開通電子發(fā)票產(chǎn)品相關(guān)功能權(quán)限,若是服務(wù)商模式,還需確認子商戶是否接受了服務(wù)商的邀請 |