微信支付開發(6) 發貨通知


由於微信支付接口更新,本文檔已過期,請查看新版微信支付教程。地址 http://www.cnblogs.com/txw1958/category/624506.html

 

 

本文介紹微信支付中發貨通知功能的實現。

 

一、發貨通知

為了更好地跟蹤訂單的情況,需要第三方在收到最終支付通知之后,調用發貨通知API告知微信后台該訂單的發貨狀態。

發貨時間限制:虛擬、服務類24小時內,實物類72小時內。

請在收到支付通知后,按時發貨,並使用發貨通知接口將相關信息同步到微信后台。若平台在規定時間內沒有收到,將視作發貨超時處理。

發貨通知API的URL為:

https://api.weixin.qq.com/pay/delivernotify?access_token=xxxxxx

URL中的參數只包含目前微信公眾平台憑證access_token,而發貨通知的真正的數據是放在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"
}

上述內容參數說明如表6-12所示。

參數

說明

appid

公眾平台賬戶的AppId;

openid

販買用戶的OpenId,這個已經放在最終支付結果通知的PostData里了;

transid

交易單號;

out_trade_no

第三方訂單號;

deliver_timestamp

發貨時間戳,這里指的是Linux時間戳;

deliver_status

發貨狀態,1表明成功,0表明失敗,失敗時需要在deliver_msg填上失敗原因;

deliver_msg

發貨狀態信息,失敗時可以填上UTF8編碼的錯諢提示信息,比如“該商品已退款”;

app_signature

根據支付簽名(paySign)生成方法中所講的簽名方式生成的,參加簽名字段為:appid、appkey、openid、transid、out_trade_no、deliver_timestamp、deliver_status、deliver_msg;

sign_method

簽名方法(不計入簽名生成);

表6-12 發貨通知參數說明

微信公眾平台在校驗ok之后,會返回數據表明是否通知成功,例如:{"errcode":0,"errmsg":"ok"}如果有異常,會在errcode和errmsg描述出來,如果成功errcode就為0。

 

二、程序實現

程序中的一些參數來自本博客前面的微信支付開發數據。讀者請參照運行

 <?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.准備參數
 $deliver_timestamp = time();
 //2.1構造最麻煩的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函數受保護,需要先取消一下,否則會報錯
 $app_signature  = $WxPayHelper->get_biz_sign($obj);

 //3. 將構造的json提交給微信服務器,查詢
 $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;
 }

 

運行后返回結果

string(27) "{"errcode":0,"errmsg":"ok"}"

====================================================================

方倍工作室微信公眾平台賬號關注方法:
1. 微信通訊錄-添加朋友-查找公眾號-搜索“方倍工作室”
2. 微信通訊錄-添加朋友-搜號碼-輸入“pondbaystudio”
3. 使用微信掃描下面的二維碼

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM