濮阳杆衣贸易有限公司

主頁 > 知識庫 > ThinkPHP框架實現(xiàn)的微信支付接口開發(fā)完整示例

ThinkPHP框架實現(xiàn)的微信支付接口開發(fā)完整示例

熱門標(biāo)簽:西區(qū)企業(yè)怎么做地圖標(biāo)注入駐 九江外呼系統(tǒng) 地下城堡2圖九地圖標(biāo)注 保定crm外呼系統(tǒng)運營商 抖音有個地圖標(biāo)注是什么意思 海南人工外呼系統(tǒng)有效果嗎 阿里云400電話申請加工單 七魚外呼系統(tǒng)停用嗎 智能電話機(jī)器人排名前十名南京

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

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

最近有個微商城做了微信支付的接口,現(xiàn)在整理一下發(fā)上來。

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

開發(fā)步驟

一、進(jìn)入公眾號平臺,先設(shè)置幾個參數(shù),包括綁定域名、設(shè)置回調(diào)地址等等。

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

 

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

 

3、在開發(fā)者中心把ldquo;網(wǎng)頁授權(quán)獲取用戶基本信息rdquo;的域名寫上自己的域名,微信登陸時需要用到的;

 

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

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

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

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

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

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

?php
namespace Home\Controller;
use Think\Controller;
//微信支付類
class WxpayController extends Controller {
  //獲取access_token過程中的跳轉(zhuǎn)uri,通過跳轉(zhuǎn)將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:網(wǎng)頁授權(quán)獲取用戶openid============
    //通過code獲得openid
    if (!isset($_GET['code'])){
      //觸發(fā)微信返回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:使用統(tǒng)一支付接口,獲取prepay_id============
    //使用統(tǒng)一支付接口
    $unifiedOrder = new \UnifiedOrder_pub();
    //設(shè)置統(tǒng)一支付接口參數(shù)
    //設(shè)置必填參數(shù)
    //appid已填,商戶無需重復(fù)填寫
    //mch_id已填,商戶無需重復(fù)填寫
    //noncestr已填,商戶無需重復(fù)填寫
    //spbill_create_ip已填,商戶無需重復(fù)填寫
    //sign已填,商戶無需重復(fù)填寫
    $total_fee = $res['order_amount']*100;
    //$total_fee = 1;
    $body = "訂單支付{$res['order_sn']}";
    $unifiedOrder->setParameter("openid", "$openid");//用戶標(biāo)識
    $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']}");//附加數(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");//商品標(biāo)記
    //$unifiedOrder->setParameter("openid","XXXX");//用戶標(biāo)識
    //$unifiedOrder->setParameter("product_id","XXXX");//商品ID
    $prepay_id = $unifiedOrder->getPrepayId();
    //=========步驟3:使用jsapi調(diào)起支付============
    $jsApi->setPrepayId($prepay_id);
    $jsApiParameters = $jsApi->getParameters();
    $wxconf = json_decode($jsApiParameters, true);
    if ($wxconf['package'] == 'prepay_id=') {
      $this->error('當(dāng)前訂單存在異常,不能使用支付');
    }
    $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)答不是成功或超時,微信認(rèn)為通知失敗,
    //微信會通過一定的策略(如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
    );
    */
    return true;
  }
}
?>

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

 

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP微信開發(fā)技巧匯總》、《php curl用法總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP中json格式數(shù)據(jù)操作技巧匯總》及《PHP針對XML文件操作技巧總結(jié)》

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

您可能感興趣的文章:
  • PHP微信支付開發(fā)實例
  • 微信支付PHP SDK之微信公眾號支付代碼詳解
  • PHP實現(xiàn)微信支付(jsapi支付)流程步驟詳解
  • ThinkPHP實現(xiàn)微信支付(jsapi支付)流程教程詳解
  • php微信支付之APP支付方法
  • 微信小程序 支付功能實現(xiàn)PHP實例詳解
  • PHP實現(xiàn)QQ、微信和支付寶三合一收款碼實例代碼
  • 微信小程序與php 實現(xiàn)微信支付的簡單實例
  • ThinkPHP框架整合微信支付之JSAPI模式圖文詳解
  • ThinkPHP框架整合微信支付之Native 掃碼支付模式一圖文詳解
  • ThinkPHP框架整合微信支付之Native 掃碼支付模式二圖文詳解
  • PHP實現(xiàn)的微信APP支付功能示例【基于TP5框架】

標(biāo)簽:韶關(guān) 涼山 梅河口 九江 十堰 甘肅 昭通 遼陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ThinkPHP框架實現(xiàn)的微信支付接口開發(fā)完整示例》,本文關(guān)鍵詞  ThinkPHP,框架,實現(xiàn),的,微信,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ThinkPHP框架實現(xiàn)的微信支付接口開發(fā)完整示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于ThinkPHP框架實現(xiàn)的微信支付接口開發(fā)完整示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    伊宁市| 洮南市| 墨玉县| 牡丹江市| 临沧市| 休宁县| 奎屯市| 澳门| 普格县| 桃园市| 夏邑县| 尼木县| 铜鼓县| 湛江市| 肃宁县| 博野县| 四会市| 景谷| 南宫市| 彭水| 怀安县| 渭南市| 炉霍县| 招远市| 扎兰屯市| 日喀则市| 庆安县| 铜川市| 奉化市| 大庆市| 介休市| 黑山县| 托克逊县| 瑞金市| 内黄县| 象山县| 舞钢市| 平江县| 广南县| 钦州市| 德化县|