微信jssdk总结


  1. 绑定域名
  2. 引入js文件

    在需要调用JS接口的页面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.0.0.js

    请注意,如果你的页面启用了https,务必引入 https://res.wx.qq.com/open/js/jweixin-1.0.0.js ,否则将无法在iOS9.0以上系统中成功使用JSSDK

  3. 通过config接口注入权限验证配置

    这一步是通过用当前的url向后台发请求拿到一系列参数。即后台会拿我的url去向微信进行认证。这里需要注意的事用于验证的当前的url写法,

    let url = location.href.split(‘#’)[0];

    务必写成以上形势。否则会在进行config时报invalid signature,

确认url是页面完整的url(请在当前页面alert(location.href.split(‘#‘)[0])确认),包括‘http(s)://‘部分,以及‘?‘后面的GET参数部分,但不包括‘#‘hash后面的部分。
确保你获取用来签名的url是动态获取的,动态页面可参见实例代码中php的实现方式。如果是html的静态页面在前端通过ajax将url传到后台签名,前端需要用js获取当前页面除去‘#‘hash部分的链接(可用location.href.split(‘#‘)[0]获取,而且需要encodeURIComponent),因为页面一旦分享,微信客户端会在你的链接末尾加入其它参数,如果不是动态获取当前链接,将导致分享后的页面签名失败。
注意这里的动态,不要随便自己拼接,同时encodeURIComponent。
$.ajax({
        type:‘GET‘,
        url: url,
        dataType: ‘jsonp‘
})
.then((data)=> {
    wx.config({
    debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
    appId: ‘‘, // 必填,公众号的唯一标识
    timestamp: , // 必填,生成签名的时间戳
    nonceStr: ‘‘, // 必填,生成签名的随机串
    signature: ‘‘,// 必填,签名,见附录1
    jsApiList: [] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});
})

4.通过ready接口处理成功验证

config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。

wx.ready (()=> {
           // alert(‘ready‘);
           //$(‘#onMenuShareAppMessage‘).on(‘click‘, ()=> {
                // 分享给朋友
                wx.onMenuShareAppMessage({
                  title: ‘‘,
                  desc: ‘‘,
                  link: shareUrl,
                  imgUrl: ‘‘,
                  trigger: function (res) {
                    // alert(‘用户点击发送给朋友‘);
                  },
                  success: function (res) {
                    alert(‘已分享‘);
                  },
                  cancel: function (res) {
                    alert(‘已取消‘);
                  },
                  fail: function (res) {
                    alert(JSON.stringify(res));
                  }
                });
            //});
            //分享到朋友圈
            wx.onMenuShareTimeline({
                title: ‘‘, // 分享标题
                link: shareUrl, // 分享链接
                imgUrl: ‘‘, // 分享图标
                success: function () {
                    alert(‘已分享‘);
                    // alert($(‘.no-num‘).html());
                },
                cancel: function () {
                    alert(‘已取消‘);
                    // 用户取消分享后执行的回调函数
                    // alert(‘取消‘);
                }
            });
        });

5.通过error接口处理失败验证

config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看

wx.error((res)=> {
      alert(res.errMsg);
})

6.基础接口

  • 分享到朋友圈接口
wx.onMenuShareTimeline({
    title: ‘‘, // 分享标题
    link: ‘‘, // 分享链接
    imgUrl: ‘‘, // 分享图标
    success: function () {
        // 用户确认分享后执行的回调函数
    },
    cancel: function () {
        // 用户取消分享后执行的回调函数
    }
});
  • 分享给好友的接口
wx.onMenuShareAppMessage({
    title: ‘‘, // 分享标题
    desc: ‘‘, // 分享描述
    link: ‘‘, // 分享链接
    imgUrl: ‘‘, // 分享图标
    type: ‘‘, // 分享类型,music、video或link,不填默认为link
    dataUrl: ‘‘, // 如果type是music或video,则要提供数据链接,默认为空
    success: function () {
        // 用户确认分享后执行的回调函数
    },
    cancel: function () {
        // 用户取消分享后执行的回调函数
    }
});

如果这里需要在分享的内容中加入用ajax异步请求拿到的内容,必须在ajax请求返回后的成功函数中再调用一次该分享接口,但是必须将分享接口放在wx.ready函数中,不能单独调用。因为客户端分享操作是一个同步操作,这时候使用 ajax的数据还没有返回。

7. 这些步骤看起来似乎比较简单,但是调试的过程中难免会遇到很多问题,因为jssdk接口还是有很多的限制的。一不小心就踩到了坑。

8. 最后,我将这个接口进行了一下封装。

‘use strict‘;
let wxDefaultOptions = {
    debug: true,
    appId: ‘‘,
    timestamp: 0,
    nonceStr: ‘‘,
    signature: ‘‘,
    jsApiList: [
    ‘checkJsApi‘,
    ‘onMenuShareTimeline‘,
    ‘onMenuShareAppMessage‘,
    ‘onMenuShareQQ‘,
    ‘onMenuShareWeibo‘,
    ‘hideMenuItems‘,
    ‘showMenuItems‘,
    ‘hideAllNonBaseMenuItem‘,
    ‘showAllNonBaseMenuItem‘,
    ‘translateVoice‘,
    ‘startRecord‘,
    ‘stopRecord‘,
    ‘onRecordEnd‘,
    ‘playVoice‘,
    ‘pauseVoice‘,
    ‘stopVoice‘,
    ‘uploadVoice‘,
    ‘downloadVoice‘,
    ‘chooseImage‘,
    ‘previewImage‘,
    ‘uploadImage‘,
    ‘downloadImage‘,
    ‘getNetworkType‘,
    ‘openLocation‘,
    ‘getLocation‘,
    ‘hideOptionMenu‘,
    ‘showOptionMenu‘,
    ‘closeWindow‘,
    ‘scanQRCode‘,
    ‘chooseWXPay‘,
    ‘openProductSpecificView‘,
    ‘addCard‘,
    ‘chooseCard‘,
    ‘openCard‘
  ]
};
//let shareUrl = ‘http://xxx‘ + location.pathname;

let getWxParam = (url, wxOptions) => {
    let url = location.href.split(‘#‘)[0];
   url = encodeURIComponent(url);
    let promise = new Promise((resolve, reject)=> {
        $.ajax({
            type:‘GET‘,
            url: ‘http://xxx/xxx?param=‘+url,
            dataType: ‘jsonp‘
        })
        .then((data)=> {
            let wxParam = data;
            console.log(wxParam);
            wxOptions.appId = ‘wxeb5c3f4a03b880f0‘;
            wxOptions.timestamp = wxParam.timestamp;
            wxOptions.nonceStr = wxParam.nonceStr;
            wxOptions.signature = wxParam.signature;
            wx.config(wxOptions);
            wx.error((res)=> {
                alert(res.errMsg);
            })
            resolve();
        }, (error)=> {
            console.log(error);
        })
    });
    return promise;
}

//分享到朋友圈
let shareSocial = (param)=> {
    wx.onMenuShareTimeline({
          title: param.title, // 分享标题
          link: param.link, // 分享链接
          imgUrl: param.imgUrl, // 分享图标
          success: function () {
              // 用户确认分享后执行的回调函数
              param.suCallback();
          },
          cancel: function () {
              // 用户取消分享后执行的回调函数
              param.failCalback();
          }
        });
}
//分享给好友
let shareToFriends = (param) => {

    wx.onMenuShareAppMessage({
          title: param.title,
          desc: param.desc,
          link: param.link,
          imgUrl: param.imgUrl,
          trigger: function (res) {

          },
          success: function (res) {
            param.suCallback();
          },
          cancel: function (res) {
          },
          fail: function (res) {
            param.failCalback();
            console.alert(JSON.stringify(res));
          }
    });
}
//title,desc,link,imgUrl,suCallback, failCalback
let jssdk = (param) => {
  wx.ready(()=> {
        //分享到朋友圈
        shareSocial(param);
        shareToFriends(param);

  })
}

function callWx(param, wxoptions) {
    getWxParam(param.url, wxOptions).then(()=> {
        jssdk(param);
    })
}
//param = {url: ‘‘, title:‘‘,desc:‘‘,link:‘‘,imgUrl:‘‘,suCallback:func, failCalback: func}
module.exports = {
    wxDefaultOptions,//更改配置
    callWx, //默认配置,进行config配置 和ready后定制微信分享内容,
}
时间: 2024-07-28 19:39:31

微信jssdk总结的相关文章

微信JS-SDK实现上传图片功能

最近在项目开放中,有一个在微信WEB项目中上传图片的需求,一开始使用了传统的<input type="file">的方式去实现,但是后面发现在使用这种传统模式时会由于手机系统的差异而导致一系列的问题,后改用微信JSSDK的方式来实现. 总的来说,利用JSSDK来实现该功能一共分为四步. 1. 调用wx.config(),初始化jssdk的配置,并在jsApiList中配置上传图片需要的四个api('chooseImage','previewImage','uploadIma

微信JS-SDK说明文档及常见问题处理

概述 微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包. 通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.位置等手机系统的能力,同时可以直接使用微信分享.扫一扫.卡券.支付等微信特有的能力,为微信用户提供更优质的网页体验. 此文档面向网页开发者介绍微信JS-SDK如何使用及相关注意事项. 使用说明 在使用微信JS-SDK对应的JS接口前,需确保公众号已获得使用对应JS接口的权限,可登录微信公众平台进入“开发者中心”查看对应的接口权限. 注意:

&#24494;&#20449;JSSDK&#19982;&#24405;&#38899;&#30456;&#20851;&#30340;&#22353;

微信JSSDK与录音相关的坑 最近一直在做微信JSSDK与录音相关的功能开发, 遇到了各种奇尺大坑, 时不时冷不丁地被坑一道, 让我时常想嘶吼: "微信JSSDK就是个大腊鸡!!!!!!!!!!" 现在工作得到阶段性成果, 有时间休息总结下, 故来整理一下这段时间碰到的bug, 希望做个前车之鉴, 劝大家谨慎入坑. checkJsApi 功能: 判断当前客户端版本是否支持指定JS接口 转载:  http://www.fwqtg.net/%E5%BE%AE%E4%BF%A1jssdk%E

微信jssdk已无力吐槽

微信强大的整合能力让企业公众号的开发迅速窜红,尤其是企业需要个性化定制的一些功能,公司在同时上线的app和触屏版的应用中,微信分享自然是不可或缺的重要一环.纵观现在大多数的微信公众号,分享大都是弹出二维码或者干脆直接使用微信右上方的分享功能分享网页链接,对于自定义分享内容这个功能就显得力不从心了,所以在公司伟大领袖的号召下,我们要自定义分享内容,分享标题,分享链接.好的,领导的精神已经发布了,接下来该我们发神经了.拿到微信jssdk开发文档的那一刻我信心百倍的告诉自己,小意思,搞得定(我知道我又

使用微信JSSDK自定义微信分享标题、描述、和图标

最近做一个项目的时候用到微信的分享 ,实现定义分享标题,图片,了解到微信在发布JSSDK后,把包括自定义分享在内的众多网页服务接口进行了统一.如果要想自定义分享自己的网页信息给好友或朋友圈,就最好使用这个统一的网页服务接口. 微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包. 通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.位置等手机系统的能力,同时可以直接使用微信分享.扫一扫.卡券.支付等微信特有的能力,为微信用户提供更优质的网页体验. 步

微信JS-SDK接口 + FLASK实现图片上传

最近在做一个项目从全球各地采集图片,考虑采用微信JS-SDK来简化开发.图片会首先上传到微信的服务器,返回一个id,然后根据这个id去微信服务器获取图片.微信提供可选择的压缩图片功能.图片首先上传到微信的服务器,可以保障较好的上传稳定性. 详细内容请参考微信的官方文档:微信JS-SDK说明文档 运行页面如下 HTML 在微信demo的基础上修改,见微信JS-SDK DEMO页面 增加图片的多次选择,多次上传,删除等功能 uploadImage.html <!DOCTYPE html> <

微信JS-SDK

微信JS-SDK 链接汇总: 微信公众平台开发者文档:http://mp.weixin.qq.com/wiki/home/index.html 新浪sea服务器:http://egret5.sinaapp.com/weixin/wx_sample.php jssdk.php  方倍工作室:http://www.cnblogs.com/txw1958/p/weixin-js-sdk-php-demo.html 开发中问题: SAE 接入微信JS-SDK不能本地写的问题:https://segmen

微信js-sdk调用

之前在做微信的时候,在微信支付还有调起微信扫一扫的时候,用过js-sdk.最近,被几个做前端的同学问到了具体的流程,想想,还是写下来好点. 微信js-sdk,是微信提供给网页开发设计者使用的,在页面上使用部分微信功能的SDK.关于它的文档,可以通过微信公众平台上获取获取.http://mp.weixin.qq.com/wiki/11/74ad127cc054f6b80759c40f77ec03db.html 关于如何开发,其实在微信的文档上面已经说得蛮清楚的了,只要按照文档来,大概就能够调得出自

微信 JSSDK .NET版

/*因为官方 微信 JSSDK 只有PHP java版本的 我自己照着PHP的翻译过来的,可供参考.欢迎指正*/ [csharp] view plaincopy在CODE上查看代码片派生到我的代码片 using System; using System.Collections.Generic; using System.Web; using System.IO; using System.Security.Cryptography; using System.Runtime.Serializat

配置并学习微信JS-SDK(1)

<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script> 微信JS-SDK demo http://demo.open.weixin.qq.com/jssdk/#menu-device 微信JS-SDK 说明文档:http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html 配置公众号:微信后台-公众号设置