這篇文章給大家分享的是有關(guān)Thinkphp如何整合微信支付功能的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)公司服務(wù)項目包括巴州網(wǎng)站建設(shè)、巴州網(wǎng)站制作、巴州網(wǎng)頁制作以及巴州網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,巴州網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到巴州省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
1、微信公眾號:
獨特的appid、appscrect、接口權(quán)限之中設(shè)置可以獲取用戶ID信息權(quán)限的域名(每個用戶對于不同公眾都會有一個特有ID,通過這個ID獲取用戶微信賬號基本信息、詳情看微信開發(fā)者文檔)、在微信支付按鈕出設(shè)置微信支付授權(quán)目錄(寫到發(fā)起請求的控制器那一層)、設(shè)置開發(fā)者微信賬號為測試白名單(用微信開發(fā)者工具的時候需要)
2、微信支付平臺:
商戶平臺登陸賬號、支付密鑰(隨時可以自行設(shè)置,只能有一個)、
3、整合進去thinkphp之中邏輯:
前端微信支付按鈕設(shè)置點擊調(diào)用支付發(fā)起控制器方法、
控制器運行,引用微信支付類、獲取用戶openid、獲取訂單數(shù)據(jù)、拼接出所有普通商戶預支付jsp需要的數(shù)據(jù),display出那個自定義的支付頁面、
在支付頁面點擊支付、調(diào)用微信提供的jspi發(fā)起支付的scripet函數(shù)發(fā)起支付、
支付完成以后頁面會重定向到(在自定義支付頁面的script函數(shù)里設(shè)置的跳轉(zhuǎn)目錄{:U('controller/function)}),并且異步(靜默)設(shè)置的異步處理訂單邏輯(記錄支付時間啦、標記為已經(jīng)支付啦、標記是微信支付啦)之類的、
代碼:
我的訂單頁面的微信支付按鈕:
發(fā)起支付控制器Wxpay:
$_GET['order_key_num'],'expire'=>3600)); S('pay_now_id',$_GET['order_key_num'],3600); } vendor('Weixinpay.WxPayPubHelper'); //使用jsapi接口 $jsApi = new \JsApi_pub(); //=========步驟1:網(wǎng)頁授權(quán)獲取用戶openid============ //通過code獲得openid if($_GET['code'] == ''){ //跳轉(zhuǎn) $redirect_uri = 'https://當前域名+模塊+控制器+方法'; $url = 'https://open.weixin.qq.com/connect/oauth3/authorize ?appid=公眾號特有IDredirect_uri='.$redirect_uri.'&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect'; header("Location: $url"); exit(); }else{ //獲取openid $url = 'https://api.weixin.qq.com/sns/oauth3/access_token ?appid=公眾號ID&secret=公眾號scrept&code='.$_GET['code'].'&grant_type=authorization_code'; $openid_arr = json_decode(file_get_contents($url),true); } $openid=$openid_arr['openid']; $pay_now_id = S('pay_now_id'); if($pay_now_id){ $id=$pay_now_id; $o = D('order_info'); $order_info = $o->where('order_id = %d',$id)->find(); if(empty($order_info['paycode'])){ $order_info['paycode'] = 'weixin'; } if($order_info['is_pay']){ $this->error('當前訂單已經(jīng)支付'); } }else{ $this->error("不存在當前訂單編號!"); } $res = array( 'order_sn' => $order_info['order_sn'], 'order_amount' => $order_info['pay_money'] ); //=========步驟2:使用統(tǒng)一支付接口,獲取prepay_id============ //使用統(tǒng)一支付接口 $unifiedOrder = new \UnifiedOrder_pub(); //設(shè)置統(tǒng)一支付接口參數(shù) //設(shè)置必填參數(shù) //appid已填,商戶無需重復填寫 //mch_id已填,商戶無需重復填寫 //noncestr已填,商戶無需重復填寫 //spbill_create_ip已填,商戶無需重復填寫 //sign已填,商戶無需重復填寫 $total_fee = $order_info['pay_money']*100; // $total_fee = $res['order_amount']; //$total_fee = 1; // var_dump($order_info['pay_money']);die; $body = "訂單支付"; $unifiedOrder->setParameter("openid", "$openid");//用戶標識 $unifiedOrder->setParameter("body", '商品采購');//商品描述 //自定義訂單號,此處僅作舉例 $unifiedOrder->setParameter("out_trade_no", $order_info['order_sn']);//商戶訂單號 $unifiedOrder->setParameter("total_fee", $total_fee);//總金額 //$unifiedOrder->setParameter("attach", "order_sn={$res['order_sn']}");//附加數(shù)據(jù) $unifiedOrder->setParameter("notify_url", \WxPayConf_pub::NOTIFY_URL);//通知地址 $unifiedOrder->setParameter("trade_type", "JSAPI");//交易類型 //非必填參數(shù),商戶可根據(jù)實際情況選填 //$unifiedOrder->setParameter("sub_mch_id","XXXX");//子商戶號 //$unifiedOrder->setParameter("device_info","XXXX");//設(shè)備號 //$unifiedOrder->setParameter("attach","XXXX");//附加數(shù)據(jù) //$unifiedOrder->setParameter("time_start","XXXX");//交易起始時間 //$unifiedOrder->setParameter("time_expire","XXXX");//交易結(jié)束時間 //$unifiedOrder->setParameter("goods_tag","XXXX");//商品標記 //$unifiedOrder->setParameter("openid","XXXX");//用戶標識 //$unifiedOrder->setParameter("product_id","XXXX");//商品ID $prepay_id = $unifiedOrder->getPrepayId(); // var_dump($prepay_id);die; //=========步驟3:使用jsapi調(diào)起支付============ $jsApi->setPrepayId($prepay_id); $jsApiParameters = $jsApi->getParameters(); $wxconf = json_decode($jsApiParameters, true); if ($wxconf['package'] == 'prepay_id=') { $this->error('當前訂單存在異常!'); } $this->assign('res', $res); $this->assign('jsApiParameters', $jsApiParameters); $this->display('jsapi'); } //異步通知url,商戶根據(jù)實際開發(fā)過程設(shè)定 public function notify_url() { vendor('Weixinpay.WxPayPubHelper'); //使用通用通知接口 $notify = new \Notify_pub(); //存儲微信的回調(diào) $xml = $GLOBALS['HTTP_RAW_POST_DATA']; $notify->saveData($xml); //驗證簽名,并回應(yīng)微信。 //對后臺通知交互時,如果微信收到商戶的應(yīng)答不是成功或超時,微信認為通知失敗, //微信會通過一定的策略(如30分鐘共8次)定期重新發(fā)起通知, //盡可能提高通知的成功率,但微信不保證通知最終能成功。 if($notify->checkSign() == FALSE){ $notify->setReturnParameter("return_code", "FAIL");//返回狀態(tài)碼 $notify->setReturnParameter("return_msg", "簽名失敗");//返回信息 }else{ $notify->setReturnParameter("return_code", "SUCCESS");//設(shè)置返回碼 } $returnXml = $notify->returnXml(); //==商戶根據(jù)實際情況設(shè)置相應(yīng)的處理流程,此處僅作舉例======= //以log文件形式記錄回調(diào)信息 //$log_name = "notify_url.log";//log文件路徑 //$this->log_result($log_name, "【接收到的notify通知】:\n".$xml."\n"); $parameter = $notify->xmlToArray($xml); //$this->log_result($log_name, "【接收到的notify通知】:\n".$parameter."\n"); if($notify->checkSign() == TRUE){ if ($notify->data["return_code"] == "FAIL") { //此處應(yīng)該更新一下訂單狀態(tài),商戶自行增刪操作 //$this->log_result($log_name, "【通信出錯】:\n".$xml."\n"); //更新訂單數(shù)據(jù)【通信出錯】設(shè)為無效訂單 echo 'error'; } else if($notify->data["result_code"] == "FAIL"){ //此處應(yīng)該更新一下訂單狀態(tài),商戶自行增刪操作 //$this->log_result($log_name, "【業(yè)務(wù)出錯】:\n".$xml."\n"); //更新訂單數(shù)據(jù)【通信出錯】設(shè)為無效訂單 echo 'error'; } else{ //$this->log_result($log_name, "【支付成功】:\n".$xml."\n"); //我這里用到一個process方法,成功返回數(shù)據(jù)后處理,返回地數(shù)據(jù)具體可以參考微信的文檔 if ($this->process($parameter)) { //處理成功后輸出success,微信就不會再下發(fā)請求了 echo 'success'; }else { //沒有處理成功,微信會間隔的發(fā)送請求 echo 'error'; } } } } //訂單處理 private function process($parameter) { //此處應(yīng)該更新一下訂單狀態(tài),商戶自行增刪操作 /* * 返回的數(shù)據(jù)最少有以下幾個 * $parameter = array( 'out_trade_no' => xxx,//商戶訂單號 'total_fee' => XXXX,//支付金額 'openid' => XXxxx,//付款的用戶ID ); */ $data = array( 'order_sn'=>$parameter['out_trade_no'], 'des'=>('訂單交易:'.$parameter['out_trade_no']), 'money'=>$parameter['total_fee'], ); orderhandlestarysdgdss($data);//這是一個common方法,他會將該訂單狀態(tài)設(shè)置為已支付之類的 return true; } } ?>
發(fā)起支付后拼接預支付數(shù)據(jù)參數(shù)(參數(shù)列表看微信普通商戶開發(fā)者文檔——微信支付——統(tǒng)一下單)display的頁面:
下
- 本次訂單需支付:¥{$res['order_amount']} 元
然后就是類文件啦:
那個cacert是證書存放目錄;證書不一定需要的;
vendor文件夾在我的文件里面找找就可以。
感謝各位的閱讀!關(guān)于“Thinkphp如何整合微信支付功能”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!