PHP實現(xiàn)微信對賬單處理
最近要做支付對賬,即檢查第三方支付與數(shù)據(jù)庫中賬單是否一一對應(yīng),涉及到微信對賬單的處理,成功時,微信賬單接口返回數(shù)據(jù)以文本表格的方式返回,第一行為表頭,后面各行為對應(yīng)的字段內(nèi)容,字段內(nèi)容跟查詢訂單或退款結(jié)果一致,具體字段說明可查閱相應(yīng)接口。
Ps:至于如何調(diào)用微信接口下載對賬單,在微信的官方SDK包中就有現(xiàn)成的方法,直接調(diào)用即可。注意對賬單接口一次只能查詢一天的數(shù)據(jù)。代碼大致如下:
// 引入微信sdk文件 require_once APP_DIR . '/ome/lib/wxpay/lib/WxPay.Api.php'; require_once APP_DIR . '/ome/lib/wxpay/log.php'; // 實列化下載對賬單對象 $input = new WxPayDownloadBill(); // 對賬單日期 $input->SetBill_date(date("Ymd", strtotime("-1 day"))); // 對賬單類型 $input->SetBill_type('ALL'); // 獲取賬單信息 $downloadBillResult = WxPayApi::downloadBill($input);
打印$downloadBillResult就會發(fā)現(xiàn)他是一個數(shù)據(jù)文本(string),本文程序需要實現(xiàn)的功能就是從這個字符串從提取每一筆訂單中的有效信息,參考代碼如下:
/** * 微信對賬單數(shù)據(jù)處理 * @param $response 對賬單數(shù)據(jù) * @return array 返回結(jié)果 */ public function deal_WeChat_response($response){ $result = array(); $response = str_replace(","," ",$response); $response = explode(PHP_EOL, $response); foreach ($response as $key=>$val){ if(strpos($val, '`') !== false){ $data = explode('`', $val); array_shift($data); // 刪除第一個元素并下標(biāo)從0開始 if(count($data) == 24){ // 處理賬單數(shù)據(jù) $result['bill'][] = array( 'pay_time' => $data[0], // 支付時間 'APP_ID' => $data[1], // app_id 'MCH_ID' => $data[2], // 商戶id 'IMEI' => $data[4], // 設(shè)備號 'order_sn_wx' => $data[5], // 微信訂單號 'order_sn_sh' => $data[6], // 商戶訂單號 'user_tag' => $data[7], // 用戶標(biāo)識 'pay_type' => $data[8], // 交易類型 'pay_status' => $data[9], // 交易狀態(tài) 'bank' => $data[10], // 付款銀行 'money_type' => $data[11], // 貨幣種類 'total_amount' => $data[12], // 總金額 'coupon_amount' => $data[13], // 代金券或立減優(yōu)惠金額 'refund_number_wx' => $data[14], // 微信退款單號 'refund_number_sh' => $data[15], // 商戶退款單號 'refund_amount' => $data[16], // 退款金額 'coupon_refund_amount' => $data[17], // 代金券或立減優(yōu)惠退款金額 'refund_type' => $data[18], // 退款類型 'refund_status' => $data[19], // 退款狀態(tài) 'goods_name' => $data[20], // 商品名稱 'service_charge' => $data[22], // 手續(xù)費 'rate' => $data[23], // 費率 ); } if(count($data) == 5){ // 統(tǒng)計數(shù)據(jù) $result['summary'] = array( 'order_num' => $data[0], // 總交易單數(shù) 'turnover' => $data[1], // 總交易額 'refund_turnover' => $data[2], // 總退款金額 'coupon_turnover' => $data[3], // 總代金券或立減優(yōu)惠退款金額 'rate_turnover' => $data[4], // 手續(xù)費總金額 ); } } } return $result; }
返回的數(shù)據(jù)分為2部分,bill節(jié)點下存放的是具體流水?dāng)?shù)據(jù),summary節(jié)點下存放的是統(tǒng)計數(shù)據(jù)
主要的思路是微信賬單返回的結(jié)果格式是固定的,可以用 '`',換行符(PHP_EOL)實現(xiàn)字符串的分割,然后每 24 個 字段為一個訂單的描述信息,最后 6 個字段為賬單的匯總信息。因此通過循環(huán)就可以遍歷整個賬單。
大家有更好的解決方案,歡迎把代碼貼出來一起交流!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
PHP中把stdClass Object轉(zhuǎn)array的幾個方法
PHP和JS通訊通常都用json,但用 json 傳過來的數(shù)組并不是標(biāo)準(zhǔn)的array,而是 stdClass 類型。那么我們可以參考下面的幾個方法進(jìn)行轉(zhuǎn)換。2014-05-05php 微信公眾平臺開發(fā)模式實現(xiàn)多客服的實例代碼
這篇文章主要介紹了php 微信公眾平臺開發(fā)模式實現(xiàn)多客服的實例代碼的相關(guān)資料,需要的朋友可以參考下2016-11-11ThinkPHP3.1新特性之多數(shù)據(jù)庫操作更加完善
對于早期版本的ThinkPHP來說,切換數(shù)據(jù)庫需要使用高級模型,而現(xiàn)在的3.1版本則可以更加輕松的解決了。這篇文章主要介紹了ThinkPHP3.1對多數(shù)據(jù)庫操作,需要的朋友可以參考下2014-06-06解決Laravel 不能創(chuàng)建 migration 的問題
今天小編就為大家分享一篇解決Laravel 不能創(chuàng)建 migration 的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10php操作MongoDB基礎(chǔ)教程(連接、新增、修改、刪除、查詢)
這篇文章主要介紹了php操作MongoDB簡明教程,包括連接、新增、修改、刪除、查詢等,需要的朋友可以參考下2014-03-03