婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > php app支付寶回調(異步通知)詳解

php app支付寶回調(異步通知)詳解

熱門標簽:h5 地圖標注 寶安400電話辦理 沈陽人工智能電銷機器人公司 智能外呼電銷系統 哈爾濱400電話辦理到易號網 合肥外呼系統app 高識別電銷機器人 電銷機器人-快迭智能 拉薩打電話機器人

之前寫過支付寶app支付的支付的后臺代碼,現在來說一下異步通知:

個人感覺支付寶的異步通知,步驟比微信簡單點,但里面的坑可是沒少多少,就一個驗簽就把我整的快瘋了….

異步通知:

1,先確定在支付的時候寫的回調地址的正確性!!!!!!

2.找到支付寶封裝的驗簽類,rsaCheckV1(這個也是在app2.0接口里面)

3.驗證回調參數

*4.檢驗訂單

先確定在支付的時候寫的回調地址的正確性!!!!!!

一定要確定回調地址的寫的是否指到是你寫回調驗證的那個放里面,別到時候在回頭找錯誤的時候,抓耳撓腮..

找到支付寶封裝的驗簽類,rsaCheckV1(這個也是在app2.0接口里面)

這是支付寶已經封裝好的類:

/** rsaCheckV1  rsaCheckV2
  * 驗證簽名
  * 在使用本方法前,必須初始化AopClient且傳入公鑰參數。
  * 公鑰是否是讀取字符串還是讀取文件,是根據初始化傳入的值判斷的。
  **/
 public function rsaCheckV1($params, $rsaPublicKeyFilePath,$signType='RSA') {
  $sign = $params['sign'];
  $params['sign_type'] = null;
  $params['sign'] = null;
  $this->alipayrsaPublicKey = $rsaPublicKeyFilePath;

  return $this->verify($this->getSignContent($params), $sign, $rsaPublicKeyFilePath,$signType);
 }
 public function rsaCheckV2($params, $rsaPublicKeyFilePath, $signType='RSA') {
  $sign = $params['sign'];
  $params['sign'] = null;
  return $this->verify($this->getSignContent($params), $sign, $rsaPublicKeyFilePath, $signType);
 }
 function verify($data, $sign, $rsaPublicKeyFilePath, $signType = 'RSA') {

  if($this->checkEmpty($this->alipayPublicKey)){

   $pubKey= $this->alipayrsaPublicKey;
   $res = "-----BEGIN PUBLIC KEY-----\n" .
    wordwrap($pubKey, 64, "\n", true) .
    "\n-----END PUBLIC KEY-----";
  }else {
   //讀取公鑰文件
   $pubKey = file_get_contents($rsaPublicKeyFilePath);
   //轉換為openssl格式密鑰
   $res = openssl_get_publickey($pubKey);
  }

  ($res) or die('支付寶RSA公鑰錯誤。請檢查公鑰文件格式是否正確'); 

  //調用openssl內置方法驗簽,返回bool值
  if ("RSA2" == $signType) {
   $result = (bool)openssl_verify($data, base64_decode($sign), $res, OPENSSL_ALGO_SHA256);
  } else {
   $result = (bool)openssl_verify($data, base64_decode($sign), $res);
  }

  if(!$this->checkEmpty($this->alipayPublicKey)) {
   //釋放資源
   openssl_free_key($res);
  }

  return $result;
 }

還有就是別把這兩個方法混淆了,前者需要傳signtype,后者不需要(前面兩個方法都會調用第三個方法),還有一點很重要,就是這個方法的本身是從文件里面提取公鑰的的,但是本人是直接傳的,就把這個方法稍加改動了一下,讓它直接讀取我傳的公鑰.這個驗簽方法返回的是(bool)true或者(bool)false,來判斷驗簽是否成功.

在這里要注意三點:

1—注意公鑰的正確性,還有用的是支付寶公鑰不是你當初生成的公鑰
2—區別這里的方法和支付寶接口本身方法的公鑰獲取方式
3—注意接口方法本身的注釋,很重要

驗證回調參數

支付寶的回調參數是以post的方式回傳的,但是我們在測試的時候可以直接把回調url直接寫在地址欄里面,然后用get方式接受,這樣就不用拼參數了,結果是一樣的(回調url可以記錄在log文件里面),還有就是驗簽的時候需要所有的回傳參數原封不動的去驗簽,而這里自己需要什么參數就接收什么參數就可以,這里就不多說了,就是正常的接受參數的問題.下面給出我在驗證參數時,檢驗訂單金額和商家編號的代碼,僅做參考(我用的tp5):

public function check($receipt_amount,$buyer_pay_amount,$order_price,$app_id,$seller_email){
  if($receipt_amount !== $order_price || $buyer_pay_amount !== $order_price){
//    echo 1;
   return $this->log('訂單支付金額有誤!');
  }
  //支付寶支付的所有參數
  $alipay_config = Config::get('alipay_config');
  if($app_id !== $alipay_config['appid']){
//   echo 2;
    return $this->log('商家編號有誤!');
  }

  //驗證收款商家是否正確
  if($seller_email !== $alipay_config['seller_id']){
//   echo 3;
   return $this->log('收款商家有誤!');
  }
  return 'success';
 }

檢驗訂單

這里主要就是檢驗庫存,這里最好用事物處理,(雖然你的訂單量可能不一定回到這個地步),下面給出我的代碼,僅做參考(tp5):

public function index($order_sn='')
 {
  if(isset($_POST['order_sn'])  empty($order_sn)){
   $order_sn = $_POST['order_sn'];
  }

  $table = self::order_info($order_sn);
  if($table == 'failure'){return 'false';}
  $oid = $table['order_id'];
  //通過訂單id $oid 查詢出訂單中物品的id
  $goodsTable = Db::name('goods');
  $allgoods = Db::name("test1")->where('o_id', $oid)->field('g_id,g_num')->select();
  foreach ($allgoods as $k => $v) {
   //事務處理
   $goodsTable->startTrans();//事物開始
   try {
    //判斷庫存數量
    $goodsTable->query('update test2 set g_num = g_num-' . $v['g_num'] . ' where g_num >= ' . $v['g_num'] . ' and gid =' . $v['g_id']);

   } catch (\Exception $e) {
    $goodsTable->rollBack();//事物回滾
   }

   $goodsTable->commit();// 事物提交
  }

  //修改訂單
  $res = Db::name('test3')->where('order_sn',$order_sn)->update(['order_state' => '1','pay_time'=>time()]);
  if($res != 0){
   return 'success';
  }
 }

接下來就是把結果返回給支付寶就可以,失敗:return ‘failure';成功:return ‘success';到這里就結束了.

還有就是在出錯后和在找bug的時候都平心靜氣一些,理智的找問題才會更快的找到問題 ( 如果實在不行就去找支付寶的人工支持,他會為你調試你的代碼,會給出一個差不多的結論,然后你再去改就會容易很多 :) ).

最后希望大家支付,回調都可以成功!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • php實現的支付寶網頁支付功能示例【基于TP5框架】
  • PHP支付寶當面付2.0代碼
  • php實現單筆轉賬到支付寶功能
  • php支付寶APP支付功能
  • PHP實現QQ、微信和支付寶三合一收款碼實例代碼
  • PHP實現支付寶即時到賬功能
  • thinkPHP框架對接支付寶即時到賬接口回調操作示例
  • PHP接入支付寶接口失效流程詳解

標簽:巴中 威海 梅州 成都 張家口 林芝 山東 泰州

巨人網絡通訊聲明:本文標題《php app支付寶回調(異步通知)詳解》,本文關鍵詞  php,app,支付,寶回,調,異步,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《php app支付寶回調(異步通知)詳解》相關的同類信息!
  • 本頁收集關于php app支付寶回調(異步通知)詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 马龙县| 屏东县| 桃江县| 堆龙德庆县| 通江县| 丹阳市| 连江县| 清水河县| 宝丰县| 台北市| 平陆县| 永靖县| 米泉市| 徐水县| 汉沽区| 得荣县| 高碑店市| 澳门| 文登市| 达孜县| 巴马| 营口市| 江永县| 定边县| 洛阳市| 湟源县| 佛山市| 分宜县| 都匀市| 锡林郭勒盟| 长岭县| 固镇县| 红桥区| 荆州市| 松溪县| 遂平县| 仁寿县| 顺平县| 温宿县| 祁门县| 波密县|