PAY頁面往 js_api_call.php 傳值 獲取不到的問題
創(chuàng)新互聯(lián)專注于成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)、網(wǎng)站制作、網(wǎng)站開發(fā)。公司秉持“客戶至上,用心服務(wù)”的宗旨,從客戶的利益和觀點(diǎn)出發(fā),讓客戶在網(wǎng)絡(luò)營銷中找到自己的駐足之地。尊重和關(guān)懷每一位客戶,用嚴(yán)謹(jǐn)?shù)膽B(tài)度對待客戶,用專業(yè)的服務(wù)創(chuàng)造價(jià)值,成為客戶值得信賴的朋友,為客戶解除后顧之憂。
echo 是可以echo出來的 但是
這里不寫死就會報(bào)錯 $key0$
?php
/**
* JS_API支付demo
* ====================================================
* 在微信瀏覽器里面打開H5網(wǎng)頁中執(zhí)行JS調(diào)起支付。接口輸入輸出數(shù)據(jù)格式為JSON。
* 成功調(diào)起支付需要三個步驟:
* 步驟1:網(wǎng)頁授權(quán)獲取用戶openid
* 步驟2:使用統(tǒng)一支付接口,獲取prepay_id
* 步驟3:使用jsapi調(diào)起支付
*/
//獲取信息
@$name="支付測試-包包";
@$price=0.01*100;
@$hyid=$_GET['hyid'];
@$out_trade_no=$_GET['num'];//訂單號
include_once("../WxPayPubHelper/WxPayPubHelper.php");
//使用jsapi接口
$jsApi = new JsApi_pub();
//=========步驟1:網(wǎng)頁授權(quán)獲取用戶openid============
//通過code獲得openid
if (!isset($_GET['code']))
{
//觸發(fā)微信返回code碼
$url = $jsApi-createOauthUrlForCode(WxPayConf_pub::JS_API_CALL_URL);
Header("Location: $url");
}else
{
//獲取code碼,以獲取openid
$code = $_GET['code'];
$jsApi-setCode($code);
$openid = $jsApi-getOpenId();
}
//=========步驟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ù)填寫
$unifiedOrder-setParameter("openid","$openid");//商品描述
$unifiedOrder-setParameter("body","$name");//商品描述
//自定義訂單號,此處僅作舉例
$timeStamp = time();
$out_trade_no = WxPayConf_pub::APPID."$timeStamp";
$unifiedOrder-setParameter("out_trade_no","$out_trade_no");//商戶訂單號
$unifiedOrder-setParameter("total_fee","$price");//總金額
$unifiedOrder-setParameter("notify_url","");//通知地址
$unifiedOrder-setParameter("trade_type","JSAPI");//交易類型
//非必填參數(shù),商戶可根據(jù)實(shí)際情況選填
//$unifiedOrder-setParameter("sub_mch_id","XXXX");//子商戶號
//$unifiedOrder-setParameter("device_info","XXXX");//設(shè)備號
//$unifiedOrder-setParameter("attach","XXXX");//附加數(shù)據(jù)
//$unifiedOrder-setParameter("time_start","XXXX");//交易起始時(shí)間
//$unifiedOrder-setParameter("time_expire","XXXX");//交易結(jié)束時(shí)間
//$unifiedOrder-setParameter("goods_tag","XXXX");//商品標(biāo)記
$unifiedOrder-setParameter("attach","2");//會員ID
$prepay_id = $unifiedOrder-getPrepayId();
//=========步驟3:使用jsapi調(diào)起支付============
$jsApi-setPrepayId($prepay_id);
$jsApiParameters = $jsApi-getParameters();
//echo $jsApiParameters;
?
html
head
meta charset="utf-8"
title支付頁面/title
script type="text/javascript"
//調(diào)用微信JS api 支付
function jsApiCall()
{
WeixinJSBridge.invoke(
'getBrandWCPayRequest',
?php echo $jsApiParameters; ?,
function(res){
WeixinJSBridge.log(res.err_msg);
if(res.err_msg == "get_brand_wcpay_requestk"){
window.location.href='/shop/successful.php?spmc=?php echo $name; ?price=?php echo $price; ?';
//history.go(-1);
}else{
window.location.href='/shop/pay.php';
}
}
);
}
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
/head
/html
.replace(/\n/g,"\\n") replace(/\r/g,"\\r") 要這個破換行干啥?JSON數(shù)據(jù)干凈點(diǎn)不好嗎?還是文本中本身就有而且是LINUX中弄的?JSON中不應(yīng)該有個回車符,要有也應(yīng)是\r\n或 \n
微信小程序中wx.request所調(diào)用域名是有嚴(yán)格規(guī)定的,不是隨便用個url就行的,下面是官方文檔的說明:
每個微信小程序需要事先設(shè)置一個通訊域名,小程序只可以跟指定的域名與進(jìn)行網(wǎng)絡(luò)通信。包括普通 HTTPS 請求(request)、上傳文件(uploadFile)、下載文件(downloadFile) 和 WebSocket 通信(connectSocket)
配置流程
服務(wù)器域名請?jiān)?「小程序后臺-設(shè)置-開發(fā)設(shè)置-服務(wù)器域名」 中進(jìn)行配置,配置時(shí)需要注意:
域名只支持?https?(request、uploadFile、downloadFile) 和?wss?(connectSocket) 協(xié)議;
域名不能使用 IP 地址或 localhost;
域名必須經(jīng)過 ICP 備案;
出于安全考慮,api.weixin.qq.com?不能被配置為服務(wù)器域名,相關(guān)API也不能在小程序內(nèi)調(diào)用。?開發(fā)者應(yīng)將 appsecret 保存到后臺服務(wù)器中,通過服務(wù)器使用 appsecret 獲取 accesstoken,并調(diào)用相關(guān) API;
對于每個接口,分別可以配置最多 20 個域名。
1、在MYSQL中新建一個test數(shù)據(jù)庫,在里面新建一張type數(shù)據(jù)表,下面將從該表獲得數(shù)據(jù)。
2、新建一個project小程序項(xiàng)目。
3、在project項(xiàng)目內(nèi),新建一個index模塊來從數(shù)據(jù)庫獲得數(shù)據(jù),并將數(shù)據(jù)輸出在index.wxml頁面。
4、在index模塊中index.js頁面,在onLoad中使用wx.request方法向服務(wù)端文件請求數(shù)據(jù)。url為請求數(shù)據(jù)的地址;data為傳輸?shù)膮?shù),這里設(shè)置為空;method為傳遞參數(shù)的方式,header用于設(shè)置請求的數(shù)據(jù)類型,success是成功獲得數(shù)據(jù)后的操作。
5、在index.wxml頁面,使用for循環(huán)遍歷輸出index.js傳遞過來的數(shù)據(jù)data,通過item將data數(shù)據(jù)輸出在頁面。
6、在服務(wù)端新建一個api.php頁面來接收微信小程序的數(shù)據(jù)請求。
7、最后編譯微信小程序,查看從數(shù)據(jù)表type獲得數(shù)據(jù)內(nèi)容,成功從數(shù)據(jù)庫讀取數(shù)據(jù)并輸出在頁面上。