微信掃碼支付零云插件版實例詳解
微信掃碼支付零云插件版實例詳解
微信的掃碼支付主要有以下過程:
向微信統(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)手機短信按鈕倒計時(超簡單)
在淘寶等購物網(wǎng)站,我們都會看到一個發(fā)送短信倒計時的按鈕,究竟是如何實現(xiàn)的呢?下面小編通過本篇文章給大家分享一段代碼關(guān)于js實現(xiàn)手機短信按鈕倒計時,需要的朋友參考下2015-12-12微信小程序wx.getUserInfo授權(quán)獲取用戶信息(頭像、昵稱)的實現(xiàn)
這篇文章主要介紹了微信小程序wx.getUserInfo授權(quán)獲取用戶信息(頭像、昵稱)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08ES6 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