博尔乐 發表於 2020-7-25 12:26:00

微信公众号和小程序开发之调用JSSDK

<p>开发者文档地址</p>
<p>首先来看看在微信公众号中的步骤:</p>
<p>第一步:绑定域名<br>先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”</p>
<p><br>第二步:引入JS文件<br>在需要调用JS接口的页面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.2.0.js</p>
<p>第三步:通过config接口注入权限验证配置(其中配置参数调用后台接口 由后台人员生成)<br>wx.config({<br>    debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。<br>    appId: '', // 必填,公众号的唯一标识<br>    timestamp: , // 必填,生成签名的时间戳<br>    nonceStr: '', // 必填,生成签名的随机串<br>    signature: '',// 必填,签名,见附录1<br>    jsApiList: [] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2<br>});<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>签名算法生成规则:查看文档</p>
<p>第四步:通过ready接口处理成功验证<br>wx.ready(function(){<br>    // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。<br>});<br>1<br>2<br>3<br>第五步:通过ready接口处理成功验证<br>wx.error(function(res){<br>    // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。<br>});<br>1<br>2<br>3<br>第六步:接口调用<br>拦截器具体实现: 参考地址<br>js 接口调用 :参考地址<br>下面介绍小程序的web-view里使用微信的JS-SDK:</p>
<p>官方文档</p>
<p>如果只是使用wx.miniProgram.navigateTo这种导航的接口,jssdk可以不用做配置,引用js后直接使用就行,如果chooseImage这种,就需要获取配置了,步骤如下:</p>
<p>先在后端通过AppID和AppSecret取到access_token,并缓存access_token<br>再通过access_token获取到jsapi_ticket,jsapi_ticket的值也要缓存<br>使用jsapi_ticket、当前URL、随机字符串、1970年1月1日00:00:00至今的秒数生成签名及及配置,返回给前端,签名记得使用https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign校验是否正确<br>前端拿到config后放到wx.config里执行<br>在wx.ready中注册事件</p>
<p>步骤比较多但是并不复杂,主要是这其中几个坑需要避开别踩到:</p>
<p>AppID和AppSecret不能用小程序的,要用公众号的,否则会报invalid url domain的错误,官方文档上并没有说明这一点,所以这个坑非常深非常隐蔽,另外这个公众号要不要与小程序关联还不清楚,我用的是关联的。</p>
<p>签名用到的当前URl不要解码,拿到的是什么就用什么,否则即使签名校验通过也会报签名错误</p>
<p>如果你用了chooseImage这个api,需要获取到选择的图片的话,官方文档上说是在success的tempFilePaths参数里,实际上并不是,是在localIds里面</p>
<p>以上就是JSSDK使用的介绍。<br>————————————————<br>版权声明:本文为CSDN博主「weixin_40226026」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。<br>原文链接:https://blog.csdn.net/weixin_40226026/java/article/details/81698512</p><br><br>
来源:https://www.cnblogs.com/zzsdream/p/13376264.html
頁: [1]
查看完整版本: 微信公众号和小程序开发之调用JSSDK