微信支付之JSAPI公眾號支付詳解
前提
本教程默認(rèn)以下幾點你已經(jīng)完全滿足:
- 開通了認(rèn)證后的服務(wù)號
- 服務(wù)號開通的微信支付的認(rèn)證
- 騰訊給你的郵件中有商戶登錄的賬號和密碼
- 擁有一個可供上傳代碼和設(shè)置回調(diào)域名的網(wǎng)站或云服務(wù)
- 有一點點php知識。
開通了認(rèn)證后的服務(wù)號服務(wù)號開通的微信支付的認(rèn)證騰訊給你的郵件中有商戶登錄的賬號和密碼擁有一個可供上傳代碼和設(shè)置回調(diào)域名的網(wǎng)站或云服務(wù)有一點點php知識。
第一步:公眾號設(shè)置
1、 你的公眾號,在支付認(rèn)證的標(biāo)簽下, 內(nèi)容應(yīng)該和下圖類似。證明公眾號已經(jīng)完成了認(rèn)證和合約的簽署。
2、 然后在微信支付–開發(fā)配置中,設(shè)置測試授權(quán)目錄和測試白名單
3、 在公眾號設(shè)置-功能設(shè)置標(biāo)簽中,設(shè)置JS接口安全域名,這個域名在認(rèn)證獲取token的過程中可能會用到。但具體如何使用目前我也不是特別的清楚,只是按照大家的思路配置完事。
第二步:下載,調(diào)試SDK
1、 進入下載頁面,選擇要下載的SDK類型,這里我們選擇的是PHP類型
2、 下載完成之后,使用IDE將SDK打開,其文件目錄應(yīng)如下所示:
3、 將這個sdk整體打包上傳到你的服務(wù)器上,或是云服務(wù)平臺。將網(wǎng)址發(fā)送到微信客戶端,打開應(yīng)該能看到如下界面
4、 點擊JSAPI支付
5、 點擊立即支付
6、 交易成功返回頁面。
第三步:修改代碼,訪問自己的商戶
1、 index.php.將第一個列表中的a標(biāo)簽中具體的網(wǎng)址,轉(zhuǎn)為你自己的網(wǎng)址,這樣你的配置才能生效。
注:這一步一定要注意,很多教程都沒說,結(jié)果我改來改去都是訪問騰訊的測試頁面。
2、 然后在jsapi.php找到如下的代碼:
//①、獲取用戶openid $tools = new JsApiPay(); $openId = $tools->GetOpenid();
3、 進入GetOpenid()函數(shù)
public function GetOpenid() { //通過code獲得openid if (!isset($_GET['code'])){ //觸發(fā)微信返回code碼 $baseUrl = urlencode('http://'.$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF'].$_SERVER['QUERY_STRING']); $url = $this->__CreateOauthUrlForCode($baseUrl); Header("Location: $url"); exit(); } else { //獲取code碼,以獲取openid $code = $_GET['code']; $openid = $this->getOpenidFromMp($code); return $openid; } }
大概說一下代碼功能:
通過baseUrl 獲取基礎(chǔ)網(wǎng)址通過url 拼裝獲取code的url然后通過header函數(shù)進行跳轉(zhuǎn)。
4、 進入lib/WxPay.Config.php文件,根據(jù)說明修改以下幾個內(nèi)容
//=======【基本信息設(shè)置】===================================== // /** * TODO: 修改這里配置為您自己申請的商戶信息 * 微信公眾號信息配置 * * APPID:綁定支付的APPID(必須配置,開戶郵件中可查看) * * MCHID:商戶號(必須配置,開戶郵件中可查看) * * KEY:商戶支付密鑰,參考開戶郵件設(shè)置(必須配置,登錄商戶平臺自行設(shè)置) * 設(shè)置地址:https://pay.weixin.qq.com/index.php/account/api_cert * * APPSECRET:公眾帳號secert(僅JSAPI支付的時候需要配置, 登錄公眾平臺,進入開發(fā)者中心可設(shè)置), * 獲取地址:https://mp.weixin.qq.com/advanced/advanced?action=dev&t=advanced/dev&token=2005451881&lang=zh_CN * @var string */ const APPID = '你的appid'; //demo:wx426b3015555a46be const MCHID = '郵件中的商戶號';//demo:1225312702 const KEY = '這個是你在商戶管理平臺-API安全中自行設(shè)置的32位字符串';//demo:e10adc3949ba59abbe56e057f20f883e const APPSECRET = '你的app密鑰';//demo:01c6d59a3f9024db6336662ac95c8e74 //=======【證書路徑設(shè)置】===================================== /** * TODO:設(shè)置商戶證書路徑 * 證書路徑,注意應(yīng)該填寫絕對路徑(僅退款、撤銷訂單時需要,可登錄商戶平臺下載, * API證書下載地址:https://pay.weixin.qq.com/index.php/account/api_cert,下載之前需要安裝商戶操作證書) * @var path */ const SSLCERT_PATH = '../cert/apiclient_cert.pem'; const SSLKEY_PATH = '../cert/apiclient_key.pem';
5、 設(shè)置Key
6、 配置完成后,基本上也就能夠如同SDK例子一樣的使用公眾號支付功能了。
支付完成后,在商戶管理平臺應(yīng)該能查到類似下面的流水信息
如果有問題
如果你點擊JSAPI支付,出現(xiàn)log.php的訪問權(quán)限問題
permission denied in example/log.php
解決方案如下:
1、 進入jsapi.php文件
2、 找到下面的代碼
require_once 'log.php'; //初始化日志 $logHandler= new CLogFileHandler("../logs/".date('Y-m-d').'.log'); $log = Log::Init($logHandler, 15);
3、 將這三句話注釋掉就行了。
//require_once 'log.php'; //初始化日志 //$logHandler= new CLogFileHandler("../logs/".date('Y-m-d').'.log'); //$log = Log::Init($logHandler, 15);
這樣應(yīng)該就可以用了。
4、 界面應(yīng)該和下面的一樣,其中金額上面,應(yīng)該顯示你注冊的商戶平臺錄入的商戶名稱。
jsapi無法使用你不是公眾號平臺關(guān)注用戶
1、 返回查看你設(shè)置的測試白名單中加入的微信號,和你測試用的微信號是否一致,不一致請設(shè)置一致
2、 微信平臺bug,你將白名單中的微信號刪除,然后重新添加一遍就可以了
jsapi報錯
1、 檢查下面的內(nèi)容,是否與你當(dāng)前的公眾號和商戶號配置是一致的。
/** * TODO: 修改這里配置為您自己申請的商戶信息 * 微信公眾號信息配置 * * APPID:綁定支付的APPID(必須配置,開戶郵件中可查看) * * MCHID:商戶號(必須配置,開戶郵件中可查看) * * KEY:商戶支付密鑰,參考開戶郵件設(shè)置(必須配置,登錄商戶平臺自行設(shè)置) * 設(shè)置地址:https://pay.weixin.qq.com/index.php/account/api_cert * * APPSECRET:公眾帳號secert(僅JSAPI支付的時候需要配置, 登錄公眾平臺,進入開發(fā)者中心可設(shè)置), * 獲取地址:https://mp.weixin.qq.com/advanced/advanced?action=dev&t=advanced/dev&token=2005451881&lang=zh_CN * @var string */ const APPID = 'demo:wx426b3015555a46be'; const MCHID = '1225312702'; const KEY = 'e10adc3949ba59abbe56e057f20f883e'; const APPSECRET = '01c6d59a3f9024db6336662ac95c8e74';
#cer商戶證書
該證書需要上傳到example目錄統(tǒng)一目錄下的cer文件中,登錄商戶平臺,下載后,覆蓋該文件夾即可
注意
測試授權(quán)目錄,和你的服務(wù)器地址,一級域名必須是一致的。否則無法通過支付驗證。
以上所述是小編給大家介紹的JSAPI公眾號支付的方法詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Laravel5.4簡單實現(xiàn)app接口Api Token認(rèn)證方法
這篇文章主要介紹了Laravel5.4簡單實現(xiàn)app接口Api Token認(rèn)證,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08PHP面向?qū)ο笾衝ew self()與 new static()的區(qū)別淺析
new static()是在PHP5.3版本中引入的新特性,無論是new static()還是new self(),都是new了一個新的對象。下面這篇文章主要給大家介紹了關(guān)于PHP面向?qū)ο笾衝ew self()與 new static()的區(qū)別,需要的朋友可以參考借鑒,下面來一起看看吧。2017-08-08PHP中通過trigger_error觸發(fā)PHP錯誤示例
這篇文章主要介紹了PHP中通過trigger_error觸發(fā)PHP錯誤示例,本文介紹了錯誤抑制符@以及通過 trigger_error 觸發(fā) PHP 錯誤示例,需要的朋友可以參考下2015-06-06