微信支付開發(fā)發(fā)貨通知實例
一、發(fā)貨通知
為了更好地跟蹤訂單的情況,需要第三方在收到最終支付通知之后,調(diào)用發(fā)貨通知API告知微信后臺該訂單的發(fā)貨狀態(tài)。
發(fā)貨時間限制:虛擬、服務(wù)類24小時內(nèi),實物類72小時內(nèi)。
請在收到支付通知后,按時發(fā)貨,并使用發(fā)貨通知接口將相關(guān)信息同步到微信后臺。若平臺在規(guī)定時間內(nèi)沒有收到,將視作發(fā)貨超時處理。
發(fā)貨通知API的URL為:
https://api.weixin.qq.com/pay/delivernotify?access_token=xxxxxx
URL中的參數(shù)只包含目前微信公眾平臺憑證access_token,而發(fā)貨通知的真正的數(shù)據(jù)是放在PostData中的,
格式如下:
{
"appid" : "wwwwb4f85f3a797777",
"openid" : "oX99MDgNcgwnz3zFN3DNmo8uwa-w",
"transid" : "111112222233333",
"out_trade_no" : "555666uuu",
"deliver_timestamp" : "1369745073",
"deliver_status" : "1",
"deliver_msg" : "ok",
"app_signature" : "53cca9d47b883bd4a5c85a9300df3da0cb48565c",
"sign_method" : "sha1"
}
上述內(nèi)容參數(shù)說明如下表所示:
| 參數(shù) | 說明 |
|---|---|
| appid | 公眾平臺賬戶的AppId; |
| openid | 販買用戶的OpenId,這個已經(jīng)放在最終支付結(jié)果通知的PostData里了; |
| transid | 交易單號; |
| out_trade_no | 第三方訂單號; |
| deliver_timestamp | 發(fā)貨時間戳,這里指的是Linux時間戳; |
| deliver_status | 發(fā)貨狀態(tài),1表明成功,0表明失敗,失敗時需要在deliver_msg填上失敗原因; |
| deliver_msg | 發(fā)貨狀態(tài)信息,失敗時可以填上UTF8編碼的錯諢提示信息,比如“該商品已退款”; |
| app_signature | 根據(jù)支付簽名(paySign)生成方法中所講的簽名方式生成的,參加簽名字段為:appid、appkey、openid、transid、out_trade_no、deliver_timestamp、deliver_status、deliver_msg; |
| sign_method | 簽名方法(不計入簽名生成); |
微信公眾平臺在校驗ok之后,會返回數(shù)據(jù)表明是否通知成功,例如:{"errcode":0,"errmsg":"ok"}如果有異常,會在errcode和errmsg描述出來,如果成功errcode就為0。
二、程序?qū)崿F(xiàn)
程序中的一些參數(shù)來自本博客前面的微信支付開發(fā)數(shù)據(jù)。讀者請參照運行
<?php
include_once("WxPayHelper.php");
//1. 獲取access token
$appid = "wx0000000000000000";
$appsecret = "e76050733ce76050733ce76050733cdd";
$url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$appsecret";
$result = https_request($url);
$jsoninfo = json_decode($result, true);
$access_token = $jsoninfo["access_token"];
//2.準(zhǔn)備參數(shù)
$deliver_timestamp = time();
//2.1構(gòu)造最麻煩的app_signature
$obj['appid'] = $appid;
$obj['appkey'] = "8mruTNOGeX8OVUlIYxIyw6kxCRvdJENpWpw8mruTNOGeX8OVUlIYxIyw6kxCRvdJENpWpw8mruTNOGeX8OVUlIYxIyw6kxCRvdJENpWpw8mruTNOGeX8OVUlIYxIyw6k";
$obj['openid'] = "o0pk9uIVnlY-fJkzFKEbQ6LJ4cFc";
$obj['transid'] = "1218614901201405273313473135";
$obj['out_trade_no'] = "JfuKdiBig4zZnE4n";
$obj['deliver_timestamp'] = $deliver_timestamp;
$obj['deliver_status'] = "1";
$obj['deliver_msg'] = "ok";
$WxPayHelper = new WxPayHelper();
//get_biz_sign函數(shù)受保護,需要先取消一下,否則會報錯
$app_signature = $WxPayHelper->get_biz_sign($obj);
//3. 將構(gòu)造的json提交給微信服務(wù)器,查詢
$jsonmenu = '
{
"appid" : "'.$obj['appid'].'",
"openid" : "'.$obj['openid'].'",
"transid" : "'.$obj['transid'].'",
"out_trade_no" : "'.$obj['out_trade_no'].'",
"deliver_timestamp" : "'.$deliver_timestamp.'",
"deliver_status" : "'.$obj['deliver_status'].'",
"deliver_msg" : "'.$obj['deliver_msg'].'",
"app_signature" : "'.$app_signature.'",
"sign_method" : "sha1"
}';
$url = "https://api.weixin.qq.com/pay/delivernotify?access_token=".$access_token;
$result = https_request($url, $jsonmenu);
var_dump($result);
function https_request($url, $data = null){
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
if (!empty($data)){
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
}
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($curl);
curl_close($curl);
return $output;
}
運行后返回結(jié)果
string(27) "{"errcode":0,"errmsg":"ok"}"
以上就是對開發(fā)微信支付發(fā)貨通知的資料整理,希望能幫到開發(fā)微支付的朋友。
相關(guān)文章
laravel 關(guān)聯(lián)關(guān)系遍歷數(shù)組的例子
今天小編就為大家分享一篇laravel 關(guān)聯(lián)關(guān)系遍歷數(shù)組的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
Zend Framework教程之Zend_Db_Table_Row用法實例分析
這篇文章主要介紹了Zend Framework教程之Zend_Db_Table_Row用法,詳細(xì)講述了Zend_Db_Table_Row的功能,并結(jié)合實例形式詳細(xì)分析了Zend_Db_Table_Row操作數(shù)據(jù)的相關(guān)技巧,需要的朋友可以參考下2016-03-03
Zend Framework教程之Zend_Config_Xml用法分析
這篇文章主要介紹了Zend Framework教程之Zend_Config_Xml用法,結(jié)合實例形式較為詳細(xì)的分析了Zend_Config_Xml的功能,使用方法及相關(guān)注意事項,需要的朋友可以參考下2016-03-03

