国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

ThinkPHP框架實現的微信支付接口開發完整示例

2024-05-05 00:08:14
字體:
來源:轉載
供稿:網友

本文實例講述了ThinkPHP框架實現的微信支付接口開發。分享給大家供大家參考,具體如下:

微信支付接口開發很簡單我們只需要在官方申請權限然后參考官方的文章即可實現支付開發了,下面來看一個簡單的例子,具體如下。

最近有個微商城做了微信支付的接口,現在整理一下發上來。

首先是需要有已開通微信支付接口的公眾號,這個相信大家都知道,開通之后微信會發一封郵件到你的郵箱,郵件的內容就是開發需要用到的一些接口信息了(包含賬號密碼之類的東西)。

開發步驟

一、進入公眾號平臺,先設置幾個參數,包括綁定域名、設置回調地址等等。

1、在設置 -> 公眾號設置 -> 功能設置 -> 設置JS接口安全域名

 ThinkPHP,微信支付

2、在微信支付 -> 開發配置 -> 配置你的js支付接口,回調地址等等,正式目錄和測試目錄都可以寫上,測試目錄需要把個人微信號先添加到白名單才能使用(提醒:用TP框架的小伙伴們在填寫支付授權目錄時可以這樣填寫:域名/index.php/控制器/,經測試是可以通過的,微信一樣能檢測到,之前看到網上有人說這樣不行,可能是現在升級了吧,呵呵,還有一個就是域名一定要是已經備過案的才行,如果是在本地進行測試的小伙伴們可以使用花生殼,我不是在打廣告,個人覺得還是挺好用的)

 ThinkPHP,微信支付

3、在開發者中心把“網頁授權獲取用戶基本信息”的域名寫上自己的域名,微信登陸時需要用到的;

 ThinkPHP,微信支付

二、到上面一大步設置完成后就可以開始我們的開發工作了;

1、用TP的小伙伴們可以用下面的包放到tp的擴展里,也可以自行到官網下載sdk包,具體目錄:ThinkPHP/Library/Vendor/,其它就可以不用管啦;

2、打開包里的WxPayPubConfig.php文件,填寫上你的微信支付的接口信息就好啦;

三、上面二大步都是配置,這一步就是寫支付類了,其實也沒什么的,復制粘貼就好了;

1、新建Wxpay控制器,當然你也可以自己命名,訪問的名稱要跟你在微信上配置的授權目錄一樣就好了;點擊這里下載Wxpay

2、代碼的地方就不多說了,下面直接上代碼;

<?phpnamespace Home/Controller;use Think/Controller;//微信支付類class WxpayController extends Controller {  //獲取access_token過程中的跳轉uri,通過跳轉將code傳入jsapi支付頁面  public function js_api_call() {    $order_sn = I('get.order_sn', '');    if (empty($order_sn)) {      header('location:'.__ROOT__.'/');    }    vendor('Weixinpay.WxPayPubHelper');    //使用jsapi接口    $jsApi = new /JsApi_pub();    //=========步驟1:網頁授權獲取用戶openid============    //通過code獲得openid    if (!isset($_GET['code'])){      //觸發微信返回code碼      $url = $jsApi->createOauthUrlForCode('域名/Wxpay/js_api_call?order_sn='.$order_sn);      //$url = $jsApi->createOauthUrlForCode(/WxPayConf_pub::JS_API_CALL_URL);      Header("Location: $url");    }else{      //獲取code碼,以獲取openid      $code = $_GET['code'];      $jsApi->setCode($code);      $openid = $jsApi->getOpenId();    }    $res = array(      'order_sn' => '20150109113322',      'order_amount' => 255    );    //=========步驟2:使用統一支付接口,獲取prepay_id============    //使用統一支付接口    $unifiedOrder = new /UnifiedOrder_pub();    //設置統一支付接口參數    //設置必填參數    //appid已填,商戶無需重復填寫    //mch_id已填,商戶無需重復填寫    //noncestr已填,商戶無需重復填寫    //spbill_create_ip已填,商戶無需重復填寫    //sign已填,商戶無需重復填寫    $total_fee = $res['order_amount']*100;    //$total_fee = 1;    $body = "訂單支付{$res['order_sn']}";    $unifiedOrder->setParameter("openid", "$openid");//用戶標識    $unifiedOrder->setParameter("body", $body);//商品描述    //自定義訂單號,此處僅作舉例    $out_trade_no = $res['order_sn'];    $unifiedOrder->setParameter("out_trade_no", $out_trade_no);//商戶訂單號    $unifiedOrder->setParameter("total_fee", $total_fee);//總金額    //$unifiedOrder->setParameter("attach", "order_sn={$res['order_sn']}");//附加數據    $unifiedOrder->setParameter("notify_url", /WxPayConf_pub::NOTIFY_URL);//通知地址    $unifiedOrder->setParameter("trade_type", "JSAPI");//交易類型    //非必填參數,商戶可根據實際情況選填    //$unifiedOrder->setParameter("sub_mch_id","XXXX");//子商戶號    //$unifiedOrder->setParameter("device_info","XXXX");//設備號    //$unifiedOrder->setParameter("attach","XXXX");//附加數據    //$unifiedOrder->setParameter("time_start","XXXX");//交易起始時間    //$unifiedOrder->setParameter("time_expire","XXXX");//交易結束時間    //$unifiedOrder->setParameter("goods_tag","XXXX");//商品標記    //$unifiedOrder->setParameter("openid","XXXX");//用戶標識    //$unifiedOrder->setParameter("product_id","XXXX");//商品ID    $prepay_id = $unifiedOrder->getPrepayId();    //=========步驟3:使用jsapi調起支付============    $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,商戶根據實際開發過程設定  public function notify_url() {    vendor('Weixinpay.WxPayPubHelper');    //使用通用通知接口    $notify = new /Notify_pub();    //存儲微信的回調    $xml = $GLOBALS['HTTP_RAW_POST_DATA'];    $notify->saveData($xml);    //驗證簽名,并回應微信。    //對后臺通知交互時,如果微信收到商戶的應答不是成功或超時,微信認為通知失敗,    //微信會通過一定的策略(如30分鐘共8次)定期重新發起通知,    //盡可能提高通知的成功率,但微信不保證通知最終能成功。    if($notify->checkSign() == FALSE){      $notify->setReturnParameter("return_code", "FAIL");//返回狀態碼      $notify->setReturnParameter("return_msg", "簽名失敗");//返回信息    }else{      $notify->setReturnParameter("return_code", "SUCCESS");//設置返回碼    }    $returnXml = $notify->returnXml();    //==商戶根據實際情況設置相應的處理流程,此處僅作舉例=======    //以log文件形式記錄回調信息    //$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") {        //此處應該更新一下訂單狀態,商戶自行增刪操作        //$this->log_result($log_name, "【通信出錯】:/n".$xml."/n");        //更新訂單數據【通信出錯】設為無效訂單        echo 'error';      }      else if($notify->data["result_code"] == "FAIL"){        //此處應該更新一下訂單狀態,商戶自行增刪操作        //$this->log_result($log_name, "【業務出錯】:/n".$xml."/n");        //更新訂單數據【通信出錯】設為無效訂單        echo 'error';      }      else{        //$this->log_result($log_name, "【支付成功】:/n".$xml."/n");        //我這里用到一個process方法,成功返回數據后處理,返回地數據具體可以參考微信的文檔        if ($this->process($parameter)) {          //處理成功后輸出success,微信就不會再下發請求了          echo 'success';        }else {          //沒有處理成功,微信會間隔的發送請求          echo 'error';        }      }    }  }  //訂單處理  private function process($parameter) {    //此處應該更新一下訂單狀態,商戶自行增刪操作    /*    * 返回的數據最少有以下幾個    * $parameter = array(      'out_trade_no' => xxx,//商戶訂單號      'total_fee' => XXXX,//支付金額      'openid' => XXxxx,//付款的用戶ID    );    */    return true;  }}?>

四、以上就是微信支付的整個流程了,掃碼支付的應該都差不多,我沒去弄了,用過的朋友也可以分享下,^_^;來上幾張支付的截圖

 ThinkPHP,微信支付

希望本文所述對大家PHP程序設計有所幫助。


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 嘉善县| 鄂尔多斯市| 泊头市| 张家界市| 信阳市| 永城市| 政和县| 新野县| 琼海市| 石泉县| 冕宁县| 噶尔县| 阳山县| 江山市| 宽城| 象州县| 上犹县| 黄平县| 西乡县| 上蔡县| 马龙县| 西华县| 阳山县| 夏津县| 那坡县| 沈阳市| 赤城县| 昆明市| 正蓝旗| 天峨县| 大荔县| 乾安县| 长白| 神木县| 梨树县| 松潘县| 丹凤县| 特克斯县| 溧水县| 靖宇县| 陕西省|