前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >微信jssdk分享接口

微信jssdk分享接口

作者头像
治电小白菜
发布2020-08-25 15:25:06
6.7K0
发布2020-08-25 15:25:06
举报
文章被收录于专栏:技术综合技术综合

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

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方法进行加密,若没有则重新请求后加密,之后将上面图中的数据发给前端.

代码语言:javascript
复制
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

代码语言:javascript
复制
  <script src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"></script>

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

代码语言:javascript
复制
 $.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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.后端接口提供
    • 1.1 使用技术
      • 1.2 步骤
      • 2.前端请求接口
        • 2.1 步骤
        • 3.注意事项
          • 3.1 个人公众号没有分享接口
            • 3.2 需要配置ip白名单和安全域名
            相关产品与服务
            云数据库 Redis
            腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档