欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信掃碼支付零云插件版實例詳解

 更新時間:2017年04月26日 15:06:05   作者:Modigliani  
這篇文章主要介紹了微信掃碼支付零云插件版實例詳解的相關(guān)資料,需要的朋友可以參考下

微信掃碼支付零云插件版實例詳解

微信的掃碼支付主要有以下過程:

向微信統(tǒng)一下單地址發(fā)送詳細的訂單信息,微信返回json數(shù)據(jù),里面包含生成二維碼的字段,使用生成二維碼的插件qrcode生成二維碼返回給前端,讓用戶掃碼完成支付,然后頁面跳轉(zhuǎn)到return_url告知用戶支付成功,微信服務(wù)器正式通知支付成功之后修改數(shù)據(jù)庫數(shù)據(jù)。

//Pay類下的主要方法
public function buildRequestForm($pay_data){
  $UNIFIED_ORDER_URL = 'weixin://wxpay/bizpayurl?sign'; //統(tǒng)一下單地址

  $data = array();
  $data['appid'] = $this->config['appid'];
  $data['mch_id'] = $this->config['mchid'];
  $data['nonce_str'] = $this->getNonceStr(32); //隨機32位字符串
  $data['sign'] = $this->MakeSign($data);  //簽名
  $data['product_id'] = $pay_data['out_trade_no'];
  $data['body'] = $pay_data['title'];
  $data['detail'] = $pay_data['title'].' Wechat Payment';
  $data['out_trade_no'] = $pay_data['out_trade_no'];
  $data['fee_type'] = 'USD'; //使用美元支付
  $data['total_fee'] = 1; //注意 單位是分
  $data['spbill_create_ip'] = $_SERVER['REMOTE_ADDR'];
  $data['notify_url'] = $this->config['notify_url'];
  $data['trade_type'] = "NATIVE"; //交易類型

  //轉(zhuǎn)為xml格式
  $xml_param = $this->ToXml($data);

  // //發(fā)送請求 使用封裝好的curl_post
  $result = $this->FromXml($this->postXmlCurl($xml_param, $this->gateway));
  if ($result['return_code'] === 'SUCCESS') {
    if ($this->CheckSign($result)) {
      $code_img = $this->get_code_src($result['code_url']);
      $return_data['code_img'] = $code_img;
      $return_data['pay_data'] = $data;
      return $return_data;
    } else {
      E("微信訂單錯誤!");
    }
  } else {
    E("微信訂單錯誤!". $result['return_msg']);
  }
}

 

/*
 * 生成二維碼
 * @param string $code_url,需要生成二維碼的地址;
 * @return $filepath,生成的二維碼圖片所在地址;
 */
public function get_code_src($code_url) {
  $QRcode = new \PHPQRCode\QRcode();
  $filename = time().$this->getNonceStr(3).'.png';
  $filepath = request()->domain() . __ROOT__ .'/Uploads/qrcode/'.$filename;
  $res = $QRcode->png($code_url,'./Uploads/qrcode/'.$filename);
  return $filepath;
}

調(diào)用過程如下:

/* 調(diào)用是在Controller的一個方法下面,這里只截取了一段,具體如何使用視自己情況而定。
 * @param string $pay_type,支付類型‘wxpay';
 * @param array $pay_info詳細的支付信息,包括訂單標(biāo)題、金額、商品數(shù)量等等信息;
 * @param array $pay_config,支付配置,包括appID,appSecrt;
 */
$pay = new Pay($info['pay_type'], $pay_config);
if($info['pay_type'] == 'wxpay' && !isset ($_SERVER['HTTP_X_WAP_PROFILE'])) {
  $return_data = $pay->buildRequestForm($info);
  $this->assign('return_data',$return_data);
  $this->assign('return_json',json_encode($return_data));
  $this->display(); //向用戶展示二維碼
  exit();
}

注:零云是基于thinkPHP的快速建站的框架,所以這個插件在TP中也適用。

 感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • 基于JavaScript實現(xiàn)手機短信按鈕倒計時(超簡單)

    基于JavaScript實現(xiàn)手機短信按鈕倒計時(超簡單)

    在淘寶等購物網(wǎng)站,我們都會看到一個發(fā)送短信倒計時的按鈕,究竟是如何實現(xiàn)的呢?下面小編通過本篇文章給大家分享一段代碼關(guān)于js實現(xiàn)手機短信按鈕倒計時,需要的朋友參考下
    2015-12-12
  • JS實現(xiàn)的倒計時效果實例(2則實例)

    JS實現(xiàn)的倒計時效果實例(2則實例)

    這篇文章主要介紹了JS實現(xiàn)的倒計時效果,列舉了兩則JavaScript倒計時效果代碼供大家參考,原理基本相似,代碼簡潔實用,需要的朋友可以參考下
    2015-12-12
  • javascript replace方法與正則表達式

    javascript replace方法與正則表達式

    replace方法的語法是:stringObj.replace(rgExp, replaceText) 其中stringObj是字符串(string),reExp可以是正則表達式對象(RegExp)也可以是字符串(string),replaceText是替代查找到的字符串。。為了幫助大家更好的理解,下面舉個簡單例子說明一下
    2008-02-02
  • 微信小程序wx.getUserInfo授權(quán)獲取用戶信息(頭像、昵稱)的實現(xiàn)

    微信小程序wx.getUserInfo授權(quán)獲取用戶信息(頭像、昵稱)的實現(xiàn)

    這篇文章主要介紹了微信小程序wx.getUserInfo授權(quán)獲取用戶信息(頭像、昵稱)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • ES6   Promise基礎(chǔ)用法(resolve、reject、then、catch,all)

    ES6   Promise基礎(chǔ)用法(resolve、reject、then、catch,a

    Promise是JavaScript中處理異步操作的對象,它有三種狀態(tài):Pending、Fulfilled、Rejected,使用new Promise創(chuàng)建Promise對象,通過resolve和reject改變狀態(tài),then和catch方法用于處理成功和失敗的結(jié)果,本文介紹ES6 Promise用法,感興趣的朋友一起看看吧
    2024-09-09
  • js判斷瀏覽器類型為ie6時不執(zhí)行

    js判斷瀏覽器類型為ie6時不執(zhí)行

    這篇文章主要介紹了js怎么判斷瀏覽器類型,當(dāng)類型為ie6時如何不執(zhí)行,需要的朋友可以參考下
    2014-06-06
  • js精確的加減乘除實例

    js精確的加減乘除實例

    下面小編就為大家?guī)硪黄猨s精確的加減乘除實例,具有非常好的參考價值。希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-11-11
  • 詳解JavaScript中的作用域

    詳解JavaScript中的作用域

    作用域是JavaScript中一個重要的概念,它決定了變量和函數(shù)在代碼中的可訪問性和可見性,了解JavaScript的作用域?qū)τ诰帉懜咝?、可維護的代碼至關(guān)重要,本文將深入介紹JavaScript作用域相關(guān)的知識點,其中包括作用域類型,作用域鏈,變量提升以及閉包等
    2023-08-08
  • 使用js獲取地址欄中傳遞的值

    使用js獲取地址欄中傳遞的值

    本篇文章是對使用js獲取地址欄中傳遞的值實現(xiàn)代碼進行了詳細的分析介紹,需要的朋友參考下
    2013-07-07
  • javascript函數(shù)中的3個高級技巧

    javascript函數(shù)中的3個高級技巧

    這篇文章主要為大家詳細介紹了javascript函數(shù)中的3個高級技巧,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09

最新評論