微信jssdk分享接口
时间:2022-07-23
本文章向大家介绍微信jssdk分享接口,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
用的测试账号, 貌似没法点击分享... 分享给好友和分享到朋友圈按钮就直接失灵...
1.后端接口提供
(测试功能 所以url就固定了)
主要就是提供下图这些数据
image.png
1.1 使用技术
- express --- 提供接口
- redis --- 缓存access_token 和 jsapi_ticket
- request --- 请求微信接口
1.2 步骤
通过appId
和appSecret
获取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
- 数据结构C#版笔记--单链表(LinkList)
- 操作系统 页式存储 页与块之间的关系详解
- 数据结构C#版笔记--双向链表(DbLinkList)
- 斐波那契数列与IE9
- DateTime.ToString()输出"年/月/日 时:分:秒"的格式
- Flash在线拍摄用户头象
- win7 64位下如何折腾Tubro C 3.0
- TweenLite的又一应用:图片的拼图加载效果
- mysql创建数据表时如何判断是否已经存在?
- 温故知新:接口的隐式实现与显式实现
- 也谈枚举ToString()性能的改进
- silverlight:利用telerik中的zip类对字符串进行压缩、解压
- 索引,视图,存储过程和触发器文档
- 重点解读:用小程序给公众号涨粉10w的7大行业案例
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 排序算法
- 并发编程框架Disruptor之高性能设计
- 3分钟短文:Laravel说要用软删除,可不要真删
- leetcode队列之设计循环双端队列
- MySQL8.0的binlog详解
- Flutter NestedScrollView实现的一个经典滑动折叠头部图片的效果
- Maven 编译拷贝资源的时候提示 UTF-8 编码信息
- Qt音视频开发30-Onvif事件订阅
- 干掉 Navicat:正版,MySQL 官方客户端真香!
- CentOS 搭建 K8S 环境教程,一次性成功,收藏了!
- IDEA 真香!找出全部未被使用的代码只用了 2 秒钟!
- ArrayList 插入 1000w 条数据之后,我怀疑了 Java 虚拟机。。。
- 本地存储应用案例 ToDoList
- jQuery 插件
- 本周AI热点回顾:RTX3080被黄牛炒上天;百度资本助力AI 制药,已有十几位博士加入;百度联手打造AI沉浸互动展中国首秀