美文网首页Java
微信jssdk分享接口

微信jssdk分享接口

作者: ZZES_ZCDC | 来源:发表于2018-09-23 18:21 被阅读1107次

    用的测试账号, 貌似没法点击分享... 分享给好友和分享到朋友圈按钮就直接失灵...

    1.后端接口提供

    (测试功能 所以url就固定了)

    主要就是提供下图这些数据


    image.png

    1.1 使用技术

    • express --- 提供接口
    • redis --- 缓存access_token 和 jsapi_ticket
    • request --- 请求微信接口

    1.2 步骤

    通过appIdappSecret 获取access_token, 再通过access_token来获取jsapi_ticket. 由于jsapi_ticket具有7200s的的时效性,所以之前先判断redis里是否又jsapi_ticket.若有则直接使用官方的实例代码中的sign方法进行加密,若没有则重新请求后加密,之后将上面图中的数据发给前端.

    const appId = ' '
    const appSecret = ' '
    app.get('/wechat', async function (req, res) {
        redis.get('jsapi_ticket', function (err, val) {
            if (err) throw new Error(err)
            if (val === null) {
                request({
                    url: `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${appId}&secret=${appSecret}`,
                    method: 'GET',
                    json: true
                }, function (error, response, body) {
                    redis.set('access_token', body.access_token, 'EX', 7200);
                    request({
                        url: `https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=${body.access_token}&type=jsapi`,
                        method: 'GET',
                        json: true
                    }, function (error, response, body) {
                        redis.set('jsapi_ticket', body.ticket, 'EX', 7200)
                        console.log(val, 1)
                        res.send(sign(body.ticket, 'https://www.zzes1314.cn/data.html'))
                    })
                })
            } else {
                res.send(sign(val, 'https://www.zzes1314.cn/data.html'))
            }
        })
    })
    

    2.前端请求接口

    用了jQuery

    2.1 步骤

    先引入js

      <script src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"></script>
    

    直接先请求后端接口拿到数据,进行wx.config,然后再进行接口配置

     $.when(
          $.ajax({
            type: "GET",
            url: '/api/wechat',
            contentType: "application/json; charset=utf-8",
            dataType: "JSON",
            success: function (res) {
              console.log('res', res)
              wx.config({
                debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
                appId: 'wx9eb6dd4eb329aceb', // 必填,公众号的唯一标识
                timestamp: res.timestamp, // 必填,生成签名的时间戳
                nonceStr: res.nonceStr, // 必填,生成签名的随机串
                signature: res.signature,// 必填,签名
                jsApiList: ['updateAppMessageShareData', 'updateTimelineShareData'] // 必填,需要使用的JS接口列表
              });
            }
          })
        ).done(function () {
          wx.ready(function () {   //需在用户可能点击分享按钮前就先调用
            wx.updateAppMessageShareData({
              title: 'test', // 分享标题
              desc: 'test列表', // 分享描述
              link: 'http://www.zzes1314.cn/data.html', // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
              imgUrl: 'https://www.zzes1314.cn/images/qrcode.png', // 分享图标
            }, function (res) {
              alert(111)
            });
            wx.updateTimelineShareData({
              title: 'test', // 分享标题
              link: 'http://www.zzes1314.cn/data.html', // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
              imgUrl: 'https://www.zzes1314.cn/images/qrcode.png', // 分享图标
            }, function (res) {
              alert(222)
            });
          });
        })
    

    3.注意事项

    3.1 个人公众号没有分享接口

    3.2 需要配置ip白名单和安全域名

    image.png
    image.png

    相关文章

      网友评论

        本文标题:微信jssdk分享接口

        本文链接:https://www.haomeiwen.com/subject/nprqoftx.html