前提
本教程默認(rèn)以下幾點(diǎn)你已經(jīng)完全滿(mǎn)足:
- 開(kāi)通了認(rèn)證后的服務(wù)號(hào)
- 服務(wù)號(hào)開(kāi)通的微信支付的認(rèn)證
- 騰訊給你的郵件中有商戶(hù)登錄的賬號(hào)和密碼
- 擁有一個(gè)可供上傳代碼和設(shè)置回調(diào)域名的網(wǎng)站或云服務(wù)
- 有一點(diǎn)點(diǎn)php知識(shí)。
開(kāi)通了認(rèn)證后的服務(wù)號(hào)服務(wù)號(hào)開(kāi)通的微信支付的認(rèn)證騰訊給你的郵件中有商戶(hù)登錄的賬號(hào)和密碼擁有一個(gè)可供上傳代碼和設(shè)置回調(diào)域名的網(wǎng)站或云服務(wù)有一點(diǎn)點(diǎn)php知識(shí)。
第一步:公眾號(hào)設(shè)置
1、 你的公眾號(hào),在支付認(rèn)證的標(biāo)簽下, 內(nèi)容應(yīng)該和下圖類(lèi)似。證明公眾號(hào)已經(jīng)完成了認(rèn)證和合約的簽署。
2、 然后在微信支付–開(kāi)發(fā)配置中,設(shè)置測(cè)試授權(quán)目錄和測(cè)試白名單
3、 在公眾號(hào)設(shè)置-功能設(shè)置標(biāo)簽中,設(shè)置JS接口安全域名,這個(gè)域名在認(rèn)證獲取token的過(guò)程中可能會(huì)用到。但具體如何使用目前我也不是特別的清楚,只是按照大家的思路配置完事。
第二步:下載,調(diào)試SDK
1、 進(jìn)入下載頁(yè)面,選擇要下載的SDK類(lèi)型,這里我們選擇的是PHP類(lèi)型
2、 下載完成之后,使用IDE將SDK打開(kāi),其文件目錄應(yīng)如下所示:
3、 將這個(gè)sdk整體打包上傳到你的服務(wù)器上,或是云服務(wù)平臺(tái)。將網(wǎng)址發(fā)送到微信客戶(hù)端,打開(kāi)應(yīng)該能看到如下界面
4、 點(diǎn)擊JSAPI支付
5、 點(diǎn)擊立即支付
6、 交易成功返回頁(yè)面。
第三步:修改代碼,訪問(wèn)自己的商戶(hù)
1、 index.php.將第一個(gè)列表中的a標(biāo)簽中具體的網(wǎng)址,轉(zhuǎn)為你自己的網(wǎng)址,這樣你的配置才能生效。
注:這一步一定要注意,很多教程都沒(méi)說(shuō),結(jié)果我改來(lái)改去都是訪問(wèn)騰訊的測(cè)試頁(yè)面。
2、 然后在jsapi.php找到如下的代碼:
//①、獲取用戶(hù)openid
$tools = new JsApiPay();
$openId = $tools->GetOpenid();
3、 進(jìn)入GetOpenid()函數(shù)
public function GetOpenid()
{
//通過(guò)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;
}
}
大概說(shuō)一下代碼功能:
通過(guò)baseUrl 獲取基礎(chǔ)網(wǎng)址通過(guò)url 拼裝獲取code的url然后通過(guò)header函數(shù)進(jìn)行跳轉(zhuǎn)。
4、 進(jìn)入lib/WxPay.Config.php文件,根據(jù)說(shuō)明修改以下幾個(gè)內(nèi)容
//=======【基本信息設(shè)置】=====================================
//
/**
* TODO: 修改這里配置為您自己申請(qǐng)的商戶(hù)信息
* 微信公眾號(hào)信息配置
*
* APPID:綁定支付的APPID(必須配置,開(kāi)戶(hù)郵件中可查看)
*
* MCHID:商戶(hù)號(hào)(必須配置,開(kāi)戶(hù)郵件中可查看)
*
* KEY:商戶(hù)支付密鑰,參考開(kāi)戶(hù)郵件設(shè)置(必須配置,登錄商戶(hù)平臺(tái)自行設(shè)置)
* 設(shè)置地址:https://pay.weixin.qq.com/index.php/account/api_cert
*
* APPSECRET:公眾帳號(hào)secert(僅JSAPI支付的時(shí)候需要配置, 登錄公眾平臺(tái),進(jìn)入開(kāi)發(fā)者中心可設(shè)置),
* 獲取地址:https://mp.weixin.qq.com/advanced/advanced?action=devt=advanced/devtoken=2005451881lang=zh_CN
* @var string
*/
const APPID = '你的appid'; //demo:wx426b3015555a46be
const MCHID = '郵件中的商戶(hù)號(hào)';//demo:1225312702
const KEY = '這個(gè)是你在商戶(hù)管理平臺(tái)-API安全中自行設(shè)置的32位字符串';//demo:e10adc3949ba59abbe56e057f20f883e
const APPSECRET = '你的app密鑰';//demo:01c6d59a3f9024db6336662ac95c8e74
//=======【證書(shū)路徑設(shè)置】=====================================
/**
* TODO:設(shè)置商戶(hù)證書(shū)路徑
* 證書(shū)路徑,注意應(yīng)該填寫(xiě)絕對(duì)路徑(僅退款、撤銷(xiāo)訂單時(shí)需要,可登錄商戶(hù)平臺(tái)下載,
* API證書(shū)下載地址:https://pay.weixin.qq.com/index.php/account/api_cert,下載之前需要安裝商戶(hù)操作證書(shū))
* @var path
*/
const SSLCERT_PATH = '../cert/apiclient_cert.pem';
const SSLKEY_PATH = '../cert/apiclient_key.pem';
5、 設(shè)置Key
6、 配置完成后,基本上也就能夠如同SDK例子一樣的使用公眾號(hào)支付功能了。
支付完成后,在商戶(hù)管理平臺(tái)應(yīng)該能查到類(lèi)似下面的流水信息
如果有問(wèn)題
如果你點(diǎn)擊JSAPI支付,出現(xiàn)log.php的訪問(wèn)權(quán)限問(wèn)題
permission denied in example/log.php
解決方案如下:
1、 進(jìn)入jsapi.php文件
2、 找到下面的代碼
require_once 'log.php';
//初始化日志
$logHandler= new CLogFileHandler("../logs/".date('Y-m-d').'.log');
$log = Log::Init($logHandler, 15);
3、 將這三句話(huà)注釋掉就行了。
//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)該顯示你注冊(cè)的商戶(hù)平臺(tái)錄入的商戶(hù)名稱(chēng)。
jsapi無(wú)法使用你不是公眾號(hào)平臺(tái)關(guān)注用戶(hù)
1、 返回查看你設(shè)置的測(cè)試白名單中加入的微信號(hào),和你測(cè)試用的微信號(hào)是否一致,不一致請(qǐng)?jiān)O(shè)置一致
2、 微信平臺(tái)bug,你將白名單中的微信號(hào)刪除,然后重新添加一遍就可以了
jsapi報(bào)錯(cuò)
1、 檢查下面的內(nèi)容,是否與你當(dāng)前的公眾號(hào)和商戶(hù)號(hào)配置是一致的。
/**
* TODO: 修改這里配置為您自己申請(qǐng)的商戶(hù)信息
* 微信公眾號(hào)信息配置
*
* APPID:綁定支付的APPID(必須配置,開(kāi)戶(hù)郵件中可查看)
*
* MCHID:商戶(hù)號(hào)(必須配置,開(kāi)戶(hù)郵件中可查看)
*
* KEY:商戶(hù)支付密鑰,參考開(kāi)戶(hù)郵件設(shè)置(必須配置,登錄商戶(hù)平臺(tái)自行設(shè)置)
* 設(shè)置地址:https://pay.weixin.qq.com/index.php/account/api_cert
*
* APPSECRET:公眾帳號(hào)secert(僅JSAPI支付的時(shí)候需要配置, 登錄公眾平臺(tái),進(jìn)入開(kāi)發(fā)者中心可設(shè)置),
* 獲取地址:https://mp.weixin.qq.com/advanced/advanced?action=devt=advanced/devtoken=2005451881lang=zh_CN
* @var string
*/
const APPID = 'demo:wx426b3015555a46be';
const MCHID = '1225312702';
const KEY = 'e10adc3949ba59abbe56e057f20f883e';
const APPSECRET = '01c6d59a3f9024db6336662ac95c8e74';
#cer商戶(hù)證書(shū)
該證書(shū)需要上傳到example目錄統(tǒng)一目錄下的cer文件中,登錄商戶(hù)平臺(tái),下載后,覆蓋該文件夾即可
注意
測(cè)試授權(quán)目錄,和你的服務(wù)器地址,一級(jí)域名必須是一致的。否則無(wú)法通過(guò)支付驗(yàn)證。
以上所述是小編給大家介紹的JSAPI公眾號(hào)支付的方法詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
您可能感興趣的文章:- Laravel5.5+ 使用API Resources快速輸出自定義JSON方法詳解
- vue 使用外部JS與調(diào)用原生API操作示例
- JS使用百度地圖API自動(dòng)獲取地址和經(jīng)緯度操作示例
- ThinkPHP框架整合微信支付之JSAPI模式圖文詳解
- rapidjson解析json代碼實(shí)例以及常見(jiàn)的json core dump問(wèn)題
- C++中rapidjson組裝繼續(xù)簡(jiǎn)化的方法
- JavaScript自定義超時(shí)API代碼實(shí)例