激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - PHP教程 - php app支付寶回調(diào)(異步通知)詳解

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

2019-09-18 11:27Gy__My PHP教程

這篇文章主要為大家詳細(xì)介紹了php app支付寶回調(diào)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

之前寫過(guò)支付寶app支付的支付的后臺(tái)代碼,現(xiàn)在來(lái)說(shuō)一下異步通知:

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

異步通知:

1,先確定在支付的時(shí)候?qū)懙幕卣{(diào)地址的正確性!!!!!!

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

3.驗(yàn)證回調(diào)參數(shù)

*4.檢驗(yàn)訂單

先確定在支付的時(shí)候?qū)懙幕卣{(diào)地址的正確性!!!!!!

一定要確定回調(diào)地址的寫的是否指到是你寫回調(diào)驗(yàn)證的那個(gè)放里面,別到時(shí)候在回頭找錯(cuò)誤的時(shí)候,抓耳撓腮..

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

這是支付寶已經(jīng)封裝好的類:

 

/** rsaCheckV1 & rsaCheckV2
  * 驗(yàn)證簽名
  * 在使用本方法前,必須初始化AopClient且傳入公鑰參數(shù)。
  * 公鑰是否是讀取字符串還是讀取文件,是根據(jù)初始化傳入的值判斷的。
  **/
 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);
   //轉(zhuǎn)換為openssl格式密鑰
   $res = openssl_get_publickey($pubKey);
  }

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

  //調(diào)用openssl內(nèi)置方法驗(yàn)簽,返回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;
 }

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

在這里要注意三點(diǎn): 

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

驗(yàn)證回調(diào)參數(shù)

支付寶的回調(diào)參數(shù)是以post的方式回傳的,但是我們?cè)跍y(cè)試的時(shí)候可以直接把回調(diào)url直接寫在地址欄里面,然后用get方式接受,這樣就不用拼參數(shù)了,結(jié)果是一樣的(回調(diào)url可以記錄在log文件里面),還有就是驗(yàn)簽的時(shí)候需要所有的回傳參數(shù)原封不動(dòng)的去驗(yàn)簽,而這里自己需要什么參數(shù)就接收什么參數(shù)就可以,這里就不多說(shuō)了,就是正常的接受參數(shù)的問(wèn)題.下面給出我在驗(yàn)證參數(shù)時(shí),檢驗(yàn)訂單金額和商家編號(hào)的代碼,僅做參考(我用的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('訂單支付金額有誤!');
  }
  //支付寶支付的所有參數(shù)
  $alipay_config = Config::get('alipay_config');
  if($app_id !== $alipay_config['appid']){
//   echo 2;
    return $this->log('商家編號(hào)有誤!');
  }

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

檢驗(yàn)訂單

這里主要就是檢驗(yàn)庫(kù)存,這里最好用事物處理,(雖然你的訂單量可能不一定回到這個(gè)地步),下面給出我的代碼,僅做參考(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'];
  //通過(guò)訂單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) {
   //事務(wù)處理
   $goodsTable->startTrans();//事物開始
   try {
    //判斷庫(kù)存數(shù)量
    $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';
  }
 }

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

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

最后希望大家支付,回調(diào)都可以成功!

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久网站免费 | 手机在线看片国产 | av在线免费在线观看 | 国内性爱视频 | 孕妇体内谢精满日本电影 | 久久9999久久 | 亚欧在线免费观看 | 国产电影精品久久 | 国产精品久久久久久久久久尿 | 精品一区二区三区中文字幕老牛 | 欧美国产成人在线 | 水卜樱一区二区av | 久久亚洲网| 九九热在线视频观看这里只有精品 | 欧美18—19sex性hd按摩 | 麻豆一区二区99久久久久 | 亚洲精品a在线观看 | 色播视频在线播放 | 亚洲自拍第一 | www.777含羞草| 亚洲成人中文字幕在线 | 黄色毛片观看 | 妇子乱av一区二区三区 | 国产一区精品在线观看 | 国外成人在线视频 | 99re色| 免费专区 - 91爱爱 | 午夜视频在线观 | 嫩草影院在线观看网站成人 | 成人区精品一区二区婷婷 | xxxx69hd一hd72 | 精品国产91久久久久久浪潮蜜月 | 天天舔天天插 | 成人午夜激情视频 | 国产精品一区99 | 久在线播放 | 视频久久免费 | 国产一区网址 | 久久精品1区2区 | av在线1 | 久久国产28 |