成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

ngrok+express解決本地環(huán)境中微信接口調(diào)試問(wèn)題

luffyZh / 3620人閱讀

摘要:在微信項(xiàng)目的開(kāi)發(fā)中,經(jīng)常需要對(duì)微信提供的接口進(jìn)行調(diào)試,比如說(shuō)錄音分享上傳圖像等接口,但是微信要求綁定安全域名才能使用其提供的一系列功能而在開(kāi)發(fā)環(huán)境中使用或者本地?zé)o法完成域名的認(rèn)證和綁定所以無(wú)法在本地調(diào)試。

在微信項(xiàng)目的開(kāi)發(fā)中,經(jīng)常需要對(duì)微信jssdk提供的接口進(jìn)行調(diào)試,比如說(shuō)錄音, 分享 ,上傳圖像等接口,但是微信jssdk要求綁定安全域名才能使用其提供的一系列功能 , 而在開(kāi)發(fā)環(huán)境中使用localhost或者本地ip無(wú)法完成域名的認(rèn)證和綁定, 所以無(wú)法在本地調(diào)試 。當(dāng)然有一種迫不得已方法 ,就是在本地開(kāi)發(fā)完 ,打包發(fā)到公司的測(cè)試服務(wù)器上 ,利用測(cè)試服務(wù)器認(rèn)證后的域名進(jìn)行調(diào)試,每次改動(dòng),調(diào)試都要發(fā)一遍測(cè)試,顯然這種方法非常麻煩且很不科學(xué),所以這篇文章就針對(duì)這個(gè)問(wèn)題介紹一下如何利用ngrok和express解決開(kāi)發(fā)環(huán)境中微信接口的調(diào)試問(wèn)題。
?
一:首先介紹一下 ngrok,ngrok主要的功能就是將本地的ip映射到外網(wǎng) ,并且分配給你一個(gè)可用的域名,通過(guò)這個(gè)域名可以讓外網(wǎng)用戶打開(kāi)你的本地的web服務(wù),使用起來(lái)也很簡(jiǎn)單,官網(wǎng)也有文檔也有詳細(xì)介紹 。這里簡(jiǎn)單的介紹一下使用方法,首先去ngrok?的官網(wǎng)下載ngrok的對(duì)應(yīng)的客戶端 ,并且注冊(cè)用戶 ,可以通過(guò)你的github賬號(hào)或者google賬號(hào)注冊(cè) ,注冊(cè)完成后再個(gè)人中心打開(kāi)auth選項(xiàng),復(fù)制這里的authtoken,如下圖:

(這里就以window版本為例),然后下載完成解壓,會(huì)有一個(gè)ngrok.exe文件,雙擊運(yùn)行會(huì)出現(xiàn)下面的命令行:
首先我們需要完成ngrok的token認(rèn)證,否則運(yùn)行會(huì)發(fā)生錯(cuò)誤,運(yùn)行一下命令ngrok authtoken ***************** //*號(hào)就是個(gè)人中心中的token ,復(fù)制下來(lái)就可以了認(rèn)證完成后,就可以操作了,上圖中的examples就是一些常用的示例命令,我們用到的就是ngrok http,后面接的參數(shù)就是你本地web服務(wù)的端口號(hào),運(yùn)行后會(huì)分配一個(gè)外網(wǎng)域名,通過(guò)這個(gè)域名就可以訪問(wèn)到你的本地web服務(wù),?
不過(guò),這個(gè)域名在重啟后就會(huì)重新分配一個(gè)新域名,導(dǎo)致重啟后需要去微信公眾平臺(tái)重新設(shè)置一下安全域名和token認(rèn)證 。比較遺憾的是在ngrok1.0的時(shí)候可以通過(guò) ngrok http subdomain=***(自定義域名) 80 固定每次的分配的域名,但是在2.0版本后,免費(fèi)用戶無(wú)法固定域名,只有付費(fèi)用戶才可以,雖然每個(gè)月只需要$5,但是對(duì)于不是經(jīng)常測(cè)試的人來(lái)說(shuō)還是完全沒(méi)有購(gòu)買欲望,關(guān)鍵是好像只支持visaa......。不過(guò)對(duì)于想要免費(fèi)固定域名的胖友來(lái)說(shuō),解決辦法還是有的,國(guó)內(nèi)有個(gè)sunny-ngrok?,可以免費(fèi)申請(qǐng)一個(gè)自定義的固定域名 ,具體教程可以去其官網(wǎng)查看,也不是很復(fù)雜,有問(wèn)題話可以在評(píng)論里面問(wèn)我,就不詳細(xì)講了。當(dāng)然想要實(shí)現(xiàn)外網(wǎng)映射的話還有很多其他方法,比如使用npm安裝的Localtunnel和花生殼等等,可以自行了解一下。

? 二:得到域名后,接下來(lái)我們要做的就是使用該域名完成微信安全域名綁定啦,我們可以去微信公眾平臺(tái)申請(qǐng)一個(gè)測(cè)試號(hào),不過(guò)這時(shí)候填寫時(shí)無(wú)法通過(guò)的,因?yàn)槲⑿耪J(rèn)證需要擁有一個(gè)自己的服務(wù)器正確響應(yīng)配置請(qǐng)求

測(cè)試號(hào)申請(qǐng)的時(shí)候填寫配置信息的url,微信服務(wù)器會(huì)發(fā)送一個(gè)get請(qǐng)求到這個(gè)地址上,get請(qǐng)求會(huì)攜帶一些參數(shù),我們需要用這些參數(shù)生成一個(gè)簽名和微信參數(shù)的簽名進(jìn)行對(duì)比,對(duì)比成功接口才會(huì)配置成功。? 因?yàn)槲⑿耪J(rèn)證需要擁有一個(gè)自己的服務(wù)器 ,所以這里我們就需要用到express搭建一個(gè)簡(jiǎn)單的服務(wù)器,用來(lái)完成微信的token認(rèn)證和生成signature(簽名),搭建的過(guò)程也很簡(jiǎn)單,參照express中文文檔,下面就貼一下官網(wǎng)的步驟:

安裝完成過(guò)后,進(jìn)入myapp目錄,創(chuàng)建一個(gè)app.js的文件 ,

var express = require("express");
var crypto = require("crypto") //使用npm安裝后引入,用來(lái)生成簽名
var http = require("request") //express的中間件,使用npm安裝,用來(lái)發(fā)出請(qǐng)求
var jsSHA = require("jssha")//jssha是微信官網(wǎng)提供的nodejs版本簽名算法,可以去官網(wǎng)下載官網(wǎng)的sample包
var app = express();
app.use(express.static("./review"))

app.get("/weixin",function (req, res) {//這個(gè)get接口就是測(cè)試號(hào)填寫的接口,用來(lái)響應(yīng)微信服務(wù)器的請(qǐng)求
    var token = "weixin" //注意這里填寫token,與微信測(cè)試號(hào)申請(qǐng)時(shí)候填寫的token要保持一致    
    var signature = req.query.signature;
    var timestamp = req.query.timestamp;    
    var nonce = req.query.nonce;    
    var echostr = req.query.echostr;   
     /*  加密/校驗(yàn)流程如下: */   
     //1. 將token、timestamp、nonce三個(gè)參數(shù)進(jìn)行字典序排序   
     var array = new Array(token,timestamp,nonce);   
     array.sort();   
     var str = array.toString().replace(/,/g,"");      
    //2. 將三個(gè)參數(shù)字符串拼接成一個(gè)字符串進(jìn)行sha1加密    
    var sha1Code = crypto.createHash("sha1");    
    var code = sha1Code.update(str,"utf-8").digest("hex");   
     //3. 開(kāi)發(fā)者獲得加密后的字符串可與signature對(duì)比,標(biāo)識(shí)該請(qǐng)求來(lái)源于微信    
    if(code===signature){        
        res.send(echostr)   
    }else{
        res.send("error");
    }  
});
var server = app.listen(80, function () {
    var host = server.address().address;
    var port = server.address().port;
    console.log("Example app listening at http://%s:%s", host, port);
});

創(chuàng)建完成后,運(yùn)行node app.js服務(wù)器就開(kāi)啟好了,上面要注意的幾點(diǎn)就是:
1:jssha不能用npm安裝,因?yàn)閚pm安裝的運(yùn)行時(shí)候會(huì)報(bào)Chosen SHA variant is not supported,必須使用官網(wǎng)提供的sample包,下載解壓后,選擇node版本,打開(kāi)后將node_module里面jssha文件復(fù)制到項(xiàng)目?jī)?nèi)的node_module里面即可;
2:這里的token值需要和微信測(cè)試號(hào)中填寫的token值一致;現(xiàn)在我們就可以開(kāi)始填寫測(cè)試號(hào)的參數(shù)了,填寫完成微信服務(wù)器就會(huì)發(fā)送請(qǐng)求給你填寫的接口了,都正確響應(yīng)的話就會(huì)彈出配置成功。
? 當(dāng)然到這還沒(méi)有結(jié)束,因?yàn)榍岸讼胍{(diào)用jssdk的接口還需要通過(guò)接口請(qǐng)求完成權(quán)限配置,這里大家可以看一下微信jssdk的說(shuō)明文檔,具體引用步驟這里就不贅述了,接口請(qǐng)求大概如下:

這個(gè)接口主要就是提交當(dāng)前的url請(qǐng)求服務(wù)端拿到相應(yīng)的參數(shù),完成權(quán)限配置,所以在express中還需要在寫一個(gè)響應(yīng)post請(qǐng)求的接口,這個(gè)接口做的主要的工作就是拿appid和appSerect(測(cè)試號(hào)提供)去請(qǐng)求微信提供的接口生成access_token,然后拿這個(gè)access_token再去請(qǐng)求微信提供的接口生成tiket,關(guān)于這兩者文檔上都有詳細(xì)說(shuō)明。最后生成簽名,代碼如下

// noncestr生成var createNonceStr = function() {
    return Math.random().toString(36).substr(2, 15);
};
// timestamp時(shí)間戳生成var createTimeStamp = function () {
    return parseInt(new Date().getTime() / 1000) + "";
};
//獲取tiket
var getTiket= function (data) { //通過(guò)access_token獲取tiket
   return new Promise((reslove,reject)=>{
        http.get(`https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=${data}&type=jsapi`,
         function(err,res,body){
             if(res.body.tiket){
                resoleve(res.body.ticket)
             }else{
                reject(err)
             }         })      })}
// 計(jì)算簽名方法
var calcSignature = function (ticket, noncestr, ts, url) {//使用jssha
    var str = "jsapi_ticket=" + ticket + "&noncestr=" + noncestr + "×tamp="+ ts +"&url=" + url;
    shaObj = new jsSHA(str, "TEXT");    return shaObj.getHash("SHA-1", "HEX");
}
//返回給前端配置信息的post接口
app.post("/weixin",function(req,res,next){
     let appId = "******"
     let appSecret = "******"
     let url = `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${appId}&secret=${appSecret }`
     http.get(url, function (err, response, body) {
       getTiket(response.body).then(resolve=>{
          let tiket = resolve//tiket
          let nonceStr = createNonceStr()//隨機(jī)字符串
          let timeStamp = createTimeStamp()//時(shí)間戳
          let signature = calcSignature(tiket,nonceStr,timeStamp,req.body.url)
          let obj = { //將前端需要的參數(shù)返回
            data:{
                appId:appId,
                timestamp:timeStamp,
                nonceStr:nonceStr,
                signature:signature
            } 
         } 
         res.end(JSON.stringify(obj))
        }).catch(err=>{})
          res.end(JSON.stringify(err))
     });})

這里要注意的是微信返回的access_token 和tiket的都有7200s的有效期,所以要進(jìn)行緩存,我的代碼中沒(méi)有寫緩存的操作代碼了,大家有兩種方法:
1.拿到access_token和tiket后,直接寫在變量中存下來(lái),有效期內(nèi)就不用繼續(xù)請(qǐng)求接口了,直接進(jìn)行簽名操作就可以了;過(guò)期后,在請(qǐng)求一次就好了,雖然這種方法有點(diǎn)笨,不過(guò)好歹有效期還算長(zhǎng)。
2.在服務(wù)器拿到access_token和tiket后,寫入本地的json文件中,具體步驟也不贅述了,然后判斷是否過(guò)期,過(guò)期后就重新請(qǐng)求,沒(méi)過(guò)期就直接讀取json文件中的數(shù)據(jù)進(jìn)行簽名。
? 最后呢,有兩種選擇:第一:把我們的前端項(xiàng)目執(zhí)行npm run build后,把dist文件放入我們的服務(wù)器文件夾中,可以直接用express的static中間件app.use(express.static("./dist"))然后微信開(kāi)發(fā)者工具,輸入分配的域名打開(kāi)我們的項(xiàng)目,這樣我們不用設(shè)置代理了,不過(guò)需要執(zhí)行build,項(xiàng)目大一點(diǎn)的話還是有點(diǎn)浪費(fèi)時(shí)間的;
第二:就是為我們的開(kāi)發(fā)環(huán)境在申請(qǐng)一個(gè)域名,因?yàn)楝F(xiàn)在腳手架的熱更新其實(shí)就是啟動(dòng)了一個(gè)webpack-dev-sever的微服務(wù)器,申請(qǐng)域名是后填寫開(kāi)發(fā)的端口號(hào)就可以了,使得開(kāi)發(fā)地址和我們的服務(wù)器地址的二級(jí)域名相同,不過(guò)對(duì)于服務(wù)器的接口,開(kāi)發(fā)環(huán)境需要設(shè)置一下代理,而且熱更新也會(huì)失效,需要手動(dòng)刷新一下,不過(guò)相對(duì)于第一種方法可能會(huì)更好一點(diǎn)。兩種方法運(yùn)行成功后查看發(fā)出請(qǐng)求如果配置成功,控制臺(tái)會(huì)出現(xiàn)配置成功的信息如下:
然后我們就可以愉快的在使用jssdk的接口了,再也不求后端,可以自己在本地測(cè)試好所有的接口了,且不是美滋滋。
? 寫的過(guò)程中已經(jīng)盡量詳細(xì)說(shuō)明了,不過(guò)難免會(huì)漏掉一些細(xì)節(jié)問(wèn)題,歡迎指正和討論。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/107407.html

相關(guān)文章

  • Koa2微信公眾號(hào)開(kāi)發(fā)(一) 本地開(kāi)發(fā)調(diào)試環(huán)境搭建

    摘要:本篇是該系列的第一篇,本地開(kāi)發(fā)環(huán)境搭建以及接入微信。若確認(rèn)此次請(qǐng)求來(lái)自微信服務(wù)器,原樣返回參數(shù)內(nèi)容,則接入生效,成為開(kāi)發(fā)者成功,否則接入失敗。 一、簡(jiǎn)介 關(guān)于微信公眾號(hào)的介紹就省略了,自行搜索。注冊(cè)過(guò)程也不說(shuō)了。我們會(huì)直接注冊(cè)測(cè)試號(hào)來(lái)實(shí)現(xiàn)代碼。這將會(huì)是個(gè)全面講解微信公眾號(hào)開(kāi)發(fā)的系列教程。本篇是該系列的第一篇,本地開(kāi)發(fā)環(huán)境搭建以及接入微信。在開(kāi)始之前最好去看看開(kāi)發(fā)者文檔微信公眾平臺(tái)技術(shù)文...

    snifes 評(píng)論0 收藏0
  • 注冊(cè)微信開(kāi)發(fā)測(cè)試號(hào)

    摘要:注冊(cè)測(cè)試號(hào)注冊(cè)的地址在這里要進(jìn)行微信公眾號(hào)的開(kāi)發(fā),那就需要一個(gè)本地的開(kāi)發(fā)環(huán)境來(lái)進(jìn)行開(kāi)發(fā)。而微信測(cè)試號(hào)就正好提供了這樣的一個(gè)環(huán)境。通俗一點(diǎn)理解微信要知道訪問(wèn)它資源是不是這個(gè)當(dāng)前測(cè)試號(hào)。 注冊(cè)測(cè)試號(hào) 注冊(cè)的地址在 這里 要進(jìn)行微信公眾號(hào)的開(kāi)發(fā),那就需要一個(gè)本地的開(kāi)發(fā)環(huán)境來(lái)進(jìn)行開(kāi)發(fā)。而微信測(cè)試號(hào)就正好提供了這樣的一個(gè)development環(huán)境。每個(gè)微信號(hào)只能對(duì)應(yīng)一個(gè)測(cè)試號(hào),但是每個(gè)測(cè)試號(hào)可以...

    channg 評(píng)論0 收藏0
  • 移動(dòng)端H5多頁(yè)開(kāi)發(fā)拍門磚經(jīng)驗(yàn)

    摘要:以下會(huì)以其中一個(gè)以公積金頁(yè)面開(kāi)發(fā)項(xiàng)目作為例子,介紹移動(dòng)端的一些常見(jiàn)問(wèn)題和使用作為進(jìn)行多頁(yè)開(kāi)發(fā)的經(jīng)驗(yàn)。所以要想在微信開(kāi)發(fā)調(diào)試工具中獲取,我們需要使用一種叫做內(nèi)網(wǎng)穿透的工具。 showImg(https://segmentfault.com/img/remote/1460000015405042?w=800&h=600);兩年前剛接觸移動(dòng)端開(kāi)發(fā),剛開(kāi)始比較疑惑,每次遇到問(wèn)題都是到社區(qū)里提問(wèn)...

    hightopo 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<