ngrok+express解决微信接口调试方法

在微信项目的开发的时候,经常需要对微信jssdk提供的接口进行调试,比如说录音, 分享 ,上传图像等接口,但是微信jssdk要求绑定安全域名才能使用其提供的一系列功能 , 而在开发环境中使用localhost或者本地ip无法完成域名的认证和绑定, 所以无法在本地调试 。当然有一种迫不得已方法 ,就是在本地开发完 ,打包发到公司的测试服务器上 ,利用测试服务器认证后的域名进行调试,每次改动,调试都要发一遍测试,显然这种方法非常麻烦且很不科学,所以这篇文章就针对这个问题介绍一下如何利用ngrok和express解决开发环境中微信接口的调试问题。

本文主要和大家介绍了使用ngrok+express解决本地环境中微信接口调试问题,需要的朋友可以参考下,希望能帮助到大家。

一:首先介绍一下ngrok,ngrok主要的功能就是将本地的ip映射到外网 ,并且分配给你一个可用的域名,通过这个域名可以让外网用户打开你的本地的web服务,使用起来也很简单,官网也有文档也有详细介绍 。这里简单的介绍一下使用方法,首先去ngrok 的官网下载ngrok的对应的客户端 ,并且注册用户 ,可以通过你的github账号或者google账号注册 ,注册完成后再个人中心打开auth选项,复制这里的authtoken,如下图:

ngrok+express解决微信接口调试方法 

(这里就以window版本为例),然后下载完成解压,会有一个ngrok.exe文件,双击运行会出现下面的命令行:

ngrok+express解决微信接口调试方法 

首先我们需要完成ngrok的token认证,否则运行会发生错误,运行一下命令

ngrok authtoken ***************** //*号就是个人中心中的token ,复制下来就可以了

认证完成后,就可以操作了,上图中的examples就是一些常用的示例命令,我们用到的就是ngrok http,后面接的参数就是你本地web服务的端口号,运行后会分配一个外网域名,通过这个域名就可以访问到你的本地web服务,

ngrok+express解决微信接口调试方法 

不过,这个域名在重启后就会重新分配一个新域名,导致重启后需要去微信公众平台重新设置一下安全域名和token认证 。比较遗憾的是在ngrok1.0的时候可以通过 ngrok http subdomain=***(自定义域名) 80 固定每次的分配的域名,但是在2.0版本后,免费用户无法固定域名,只有付费用户才可以,虽然每个月只需要$5,但是对于不是经常测试的人来说还是完全没有购买欲望,关键是好像只支持visaa……。不过对于想要免费固定域名的胖友来说,解决办法还是有的,国内有个sunny-ngrok ,可以免费申请一个自定义的固定域名 ,具体教程可以去其官网查看,也不是很复杂,有问题话可以在评论里面问我,就不详细讲了。当然想要实现外网映射的话还有很多其他方法,比如使用npm安装的Localtunnel和花生壳等等,可以自行了解一下。

二:得到域名后,接下来我们要做的就是使用该域名完成微信安全域名绑定啦,我们可以去微信公众平台申请一个测试号,不过这时候填写时无法通过的,因为微信认证需要拥有一个自己的服务器正确响应配置请求

ngrok+express解决微信接口调试方法 

测试号申请的时候填写配置信息的url,微信服务器会发送一个get请求到这个地址上,get请求会携带一些参数,我们需要用这些参数生成一个签名和微信参数的签名进行对比,对比成功接口才会配置成功。

因为微信认证需要拥有一个自己的服务器 ,所以这里我们就需要用到express搭建一个简单的服务器,用来完成微信的token认证和生成signature(签名),搭建的过程也很简单,参照express中文文档,下面就贴一下官网的步骤:

ngrok+express解决微信接口调试方法 

安装完成过后,进入myapp目录,创建一个app.js的文件 ,

var express = require('express');var crypto = require('crypto') //使用npm安装后引入,用来生成签名var http = require('request') //express的中间件,使用npm安装,用来发出请求var jsSHA = require('jssha')//jssha是微信官网提供的nodejs版本签名算法,可以去官网下载官网的sample包var app = express();app.use(express.static('./review'))app.get('/weixin',function (req, res) {//这个get接口就是测试号填写的接口,用来响应微信服务器的请求  var token = 'weixin' //注意这里填写token,与微信测试号申请时候填写的token要保持一致    var signature = req.query.signature;  var timestamp = req.query.timestamp;    var nonce = req.query.nonce;    var echostr = req.query.echostr;     /* 加密/校验流程如下: */     //1. 将token、timestamp、nonce三个参数进行字典序排序     var array = new Array(token,timestamp,nonce);     array.sort();     var str = array.toString().replace(/,/g,"");     //2. 将三个参数字符串拼接成一个字符串进行sha1加密    var sha1Code = crypto.createHash("sha1");    var code = sha1Code.update(str,'utf-8').digest("hex");     //3. 开发者获得加密后的字符串可与signature对比,标识该请求来源于微信    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);});

登录后复制

创建完成后,运行

node app.js

服务器就开启好了,上面要注意的几点就是:

1:jssha不能用npm安装,因为npm安装的运行时候会报 Chosen SHA variant is not supported

,必须使用官网提供的sample包,下载解压后,选择node版本,打开后将node_module里面jssha文件复制到项目内的node_module里面即可;

2:这里的token值需要和微信测试号中填写的token值一致;

现在我们就可以开始填写测试号的参数了,填写完成微信服务器就会发送请求给你填写的接口了,都正确响应的话就会弹出配置成功。

当然到这还没有结束,因为前端想要调用jssdk的接口还需要通过接口请求完成权限配置,这里大家可以看一下微信jssdk的说明文档,具体引用步骤这里就不赘述了,接口请求大概如下:

ngrok+express解决微信接口调试方法 

这个接口主要就是提交当前的url请求服务端拿到相应的参数,完成权限配置,所以在express中还需要在写一个响应post请求的接口,这个接口做的主要的工作就是拿appid和appSerect(测试号提供)去请求微信提供的接口生成access_token,然后拿这个access_token再去请求微信提供的接口生成tiket,关于这两者文档上都有详细说明。最后生成签名,代码如下

// noncestr生成var createNonceStr = function() {  return Math.random().toString(36).substr(2, 15);};// timestamp时间戳生成var createTimeStamp = function () {  return parseInt(new Date().getTime() / 1000) + '';};//获取tiketvar getTiket= function (data) { //通过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)       }     })   })}// 计算签名方法var calcSignature = function (ticket, noncestr, ts, url) {//使用jssha  var str = 'jsapi_ticket=' + ticket + '&noncestr=' + noncestr + '&timestamp='+ 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()//随机字符串     let timeStamp = createTimeStamp()//时间戳     let signature = calcSignature(tiket,nonceStr,timeStamp,req.body.url)     let obj = { //将前端需要的参数返回      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的有效期,所以要进行缓存,我的代码中没有写缓存的操作代码了,大家有两种方法:

1.拿到access_token和tiket后,直接写在变量中存下来,有效期内就不用继续请求接口了,直接进行签名操作就可以了;过期后,在请求一次就好了,虽然这种方法有点笨,不过好歹有效期还算长。

2.在服务器拿到access_token和tiket后,写入本地的json文件中,具体步骤也不赘述了,然后判断是否过期,过期后就重新请求,没过期就直接读取json文件中的数据进行签名。

最后呢,有两种选择:

第一:把我们的前端项目执行 npm run build 后,把dist文件放入我们的服务器文件夹中,可以直接用express的static中间件

app.use(express.static(‘./dist’))

然后微信开发者工具,输入分配的域名打开我们的项目,这样我们不用设置代理了,不过需要执行build,项目大一点的话还是有点浪费时间的;

第二:就是为我们的开发环境在申请一个域名,因为现在脚手架的热更新其实就是启动了一个webpack-dev-sever的微服务器,申请域名是后填写开发的端口号就可以了,使得开发地址和我们的服务器地址的二级域名相同,不过对于服务器的接口,开发环境需要设置一下代理,而且热更新也会失效,需要手动刷新一下,不过相对于第一种方法可能会更好一点。

两种方法运行成功后查看发出请求如果配置成功,控制台会出现配置成功的信息如下:

ngrok+express解决微信接口调试方法 

然后我们就可以愉快的在使用jssdk的接口了,再也不求后端,可以自己在本地测试好所有的接口了,且不是美滋滋。

相关推荐:

【微信接口库】分享10个常用的php微信接口类

详解使用php调用微信接口上传永久素材

微信接口开发的详细介绍

以上就是ngrok+express解决微信接口调试方法的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2785777.html

(0)
上一篇 2025年3月8日 17:32:30
下一篇 2025年2月27日 10:27:52

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • mui js返回刷新页面的方法实例代码

    本文主要和大家分享mui j 返回刷新页面的方法实例代码,希望能帮助到大家。 mui js 返回刷新页面方法 目前只知道以下几个 mui.plusReady(function() {var primaryBack = mui.back;  …

    编程技术 2025年3月8日
    200
  • 原生js实现简单封装方法

    本文主要和大家分享原生js实现简单封装方法,本文和大家分享的代码希望能帮助到大家。 const ListenerFN = function ({ target, event, FN, option = {} }) {  if (target…

    编程技术 2025年3月8日
    200
  • vue中引入外部js方法实例

    我们在做vue项目时,经常会需要引入js,常用的有以下几种。本文主要和大家分享vue中引入外部js方法实例,希望能帮助到大家。 第一种 import XX from “路径”Vue.use(XX);这里的js文件要导出用export def…

    编程技术 2025年3月8日
    200
  • js获取键盘事件的方法实例

    本文主要和大家分享js获取键盘事件的方法实例,希望能帮助到大家。 document.onkeydown=function(event){ var e = event || window.event || arguments.callee.c…

    编程技术 2025年3月8日
    200
  • React组件性能优化方法解答

    不要将性能优化的精力浪费在对整体性能提高不大的代码上,而对性能有关键影响的部分,优化并不嫌早。因为,对性能影响最关键的部分,往往涉及解决方案核心,决定整体的架构,将来要改变的时候牵扯更大。 1. 单个React组件的性能优化 React利用…

    编程技术 2025年3月8日
    200
  • vue实现select选中值不更改方法

    本文主要为大家分享一篇解决vue 更改计算属性后select选中值不更改的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧,希望能帮助到大家。 先上代码: //… {{item.value}} {{selected}…

    2025年3月8日
    200
  • React组件的性能优化方法

    1. 单个react组件的性能优化 React利用Virtual DOM来提升渲染性能,虽然每一次页面更新都是最组件的从新渲染,但是并不是将之前的渲染内容全部抛弃重来,借助Virtual DOM,React能够计算出对DOM树的最少修改,这…

    编程技术 2025年3月8日
    200
  • 3种mysql分表的方法

    一,先说一下为什么要分表 当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了。分表的目的就在于此,减小数据库的负担,缩短查询时间。 根据个人经验,mysql执行一个sql的过程如下: 1,接收到…

    编程技术 2025年3月8日
    200
  • 监听JS变量的变化方法实例

    我现在有这样一个需求,需要监控js的某个变量的改变, 如果该变量发生变化,则触发一些事件, 不能使用timeinterval之类的定时去监控的方法, 不知道有比较好的解决方案么? 流行的MVVM的JS库/框架都有共同的特点就是数据绑定, 在…

    编程技术 2025年3月8日
    200
  • 六种JS数组去重的方法分享

    方法一: 双层循环,外层循环元素,内层循环时比较值 如果有相同的值则跳过,不相同则push进数组 本文主要和大家分享六种JS数组去重的方法,希望能帮助到大家。 Array.prototype.distinct =function(){ va…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论