1.先申請微信支付(略)javascript
2.獲取4大參數php
1.APP惟一憑證(appid):(微信公衆號->基本配置)html
2.應用密鑰(appsecret):(微信公衆號->基本配置)java
3.微信支付商戶號(partner ID):(微信商戶平臺(申請微信支付後,在郵箱中得到帳號))api
3.API密鑰:(微信商戶平臺(申請微信支付後,在郵箱中得到帳號密碼)->帳戶中心->API安全->設置API密鑰(建議md5加密))數組
下載微信支付SDK文檔安全
打開 lib/WxPay.Config.php服務器
<?php /** * 配置帳號信息 */ class WxPayConfig { //=======【基本信息設置】===================================== // /** * TODO: 修改這裏配置爲您本身申請的商戶信息 * 微信公衆號信息配置 * * APPID:綁定支付的APPID(必須配置,開戶郵件中可查看) * * MCHID:商戶號(必須配置,開戶郵件中可查看) * * KEY:商戶支付密鑰,參考開戶郵件設置(必須配置,登陸商戶平臺自行設置) * 設置地址:https://pay.weixin.qq.com/index.php/account/api_cert * * APPSECRET:公衆賬號secert(僅JSAPI支付的時候須要配置, 登陸公衆平臺,進入開發者中心可設置), * 獲取地址:https://mp.weixin.qq.com/advanced/advanced?action=dev&t=advanced/dev&token=2005451881&lang=zh_CN * @var string */ const APPID = '本身填寫'; //須要修改 const MCHID = '本身填寫';//須要修改 const KEY = '本身填寫';//須要修改 const APPSECRET = '本身填寫';//須要修改 //=======【證書路徑設置】===================================== /** * TODO:設置商戶證書路徑 * 證書路徑,注意應該填寫絕對路徑(僅退款、撤銷訂單時須要,可登陸商戶平臺下載, * 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'; //=======【curl代理設置】=================================== /** * TODO:這裏設置代理機器,只有須要代理的時候才設置,不須要代理,請設置爲0.0.0.0和0 * 本例程經過curl使用HTTP POST方法,此處可修改代理服務器, * 默認CURL_PROXY_HOST=0.0.0.0和CURL_PROXY_PORT=0,此時不開啓代理(若有須要才設置) * @var unknown_type */ const CURL_PROXY_HOST = "0.0.0.0";//"10.152.18.220"; const CURL_PROXY_PORT = 0;//8080; //=======【上報信息配置】=================================== /** * TODO:接口調用上報等級,默認緊錯誤上報(注意:上報超時間爲【1s】,上報不管成敗【永不拋出異常】, * 不會影響接口調用流程),開啓上報以後,方便微信監控請求調用的質量,建議至少 * 開啓錯誤上報。 * 上報等級,0.關閉上報; 1.僅錯誤出錯上報; 2.全量上報 * @var int */ const REPORT_LEVENL = 1; }
2.打開 example/jsapi.php微信
<?php ini_set('date.timezone','Asia/Shanghai'); //error_reporting(E_ERROR); require_once "../lib/WxPay.Api.php"; require_once "WxPay.JsApiPay.php"; require_once 'log.php'; //初始化日誌 $logHandler= new CLogFileHandler("../logs/".date('Y-m-d').'.log'); $log = Log::Init($logHandler, 15); //打印輸出數組信息 function printf_info($data) { foreach($data as $key=>$value){ echo "<font color='#00ff55;'>$key</font> : $value <br/>"; } } //①、獲取用戶openid $tools = new JsApiPay(); $openId = $tools->GetOpenid(); //②、統一下單 $input = new WxPayUnifiedOrder(); $input->SetBody("test"); $input->SetAttach("test"); $input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis")); $input->SetTotal_fee("1"); $input->SetTime_start(date("YmdHis")); $input->SetTime_expire(date("YmdHis", time() + 600)); $input->SetGoods_tag("test"); $input->SetNotify_url("填寫你的異步回調地址"); $input->SetTrade_type("JSAPI"); $input->SetOpenid($openId); $order = WxPayApi::unifiedOrder($input); echo '<font color="#f00"><b>統一下單支付單信息</b></font><br/>'; printf_info($order); $jsApiParameters = $tools->GetJsApiParameters($order); //獲取共享收貨地址js函數參數 $editAddress = $tools->GetEditAddressParameters(); //③、在支持成功回調通知中處理成功以後的事宜,見 notify.php /** * 注意: * 一、當你的回調地址不可訪問的時候,回調通知會失敗,能夠經過查詢訂單來確認支付是否成功 * 二、jsapi支付時須要填入用戶openid,WxPay.JsApiPay.php中有獲取openid流程 (文檔能夠參考微信公衆平臺「網頁受權接口」, * 參考http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html) */ ?> <html> <head> <meta http-equiv="content-type" content="text/html;charset=utf-8"/> <meta name="viewport" content="width=device-width, initial-scale=1"/> <title>微信支付樣例-支付</title> <script type="text/javascript"> //調用微信JS api 支付 function jsApiCall() { WeixinJSBridge.invoke( 'getBrandWCPayRequest', <?php echo $jsApiParameters; ?>, function(res){ WeixinJSBridge.log(res.err_msg); alert(res.err_code+res.err_desc+res.err_msg); } ); } function callpay() { if (typeof WeixinJSBridge == "undefined"){ if( document.addEventListener ){ document.addEventListener('WeixinJSBridgeReady', jsApiCall, false); }else if (document.attachEvent){ document.attachEvent('WeixinJSBridgeReady', jsApiCall); document.attachEvent('onWeixinJSBridgeReady', jsApiCall); } }else{ jsApiCall(); } } </script> <script type="text/javascript"> //獲取共享地址 function editAddress() { WeixinJSBridge.invoke( 'editAddress', <?php echo $editAddress; ?>, function(res){ var value1 = res.proviceFirstStageName; var value2 = res.addressCitySecondStageName; var value3 = res.addressCountiesThirdStageName; var value4 = res.addressDetailInfo; var tel = res.telNumber; alert(value1 + value2 + value3 + value4 + ":" + tel); } ); } window.onload = function(){ if (typeof WeixinJSBridge == "undefined"){ if( document.addEventListener ){ document.addEventListener('WeixinJSBridgeReady', editAddress, false); }else if (document.attachEvent){ document.attachEvent('WeixinJSBridgeReady', editAddress); document.attachEvent('onWeixinJSBridgeReady', editAddress); } }else{ editAddress(); } }; </script> </head> <body> <br/> <font color="#9ACD32"><b>該筆訂單支付金額爲<span style="color:#f00;font-size:50px">1分</span>錢</b></font><br/><br/> <div align="center"> <button style="width:210px; height:50px; border-radius: 15px;background-color:#FE6714; border:0px #FE6714 solid; cursor: pointer; color:white; font-size:16px;" type="button" onclick="callpay()" >當即支付</button> </div> </body> </html>
到此,SDK代碼基本配置完成app
3.設置網頁受權
微信公衆號->接口權限->網頁受權->更改回調域名
4.配置微信支付目錄
微信公衆號->微信支付->開發配置 更改微信支付目錄
OK~~ 你能夠去測試拉,基本到這裏就能夠用了。
然而,這裏不少人還不知道怎麼處理訂單狀態什麼的,
你能夠在異步回調的文件裏處理就Ok啦
異步回調地址上面也提過了,
$input->SetNotify_url("填寫你的異步回調地址");