前端微信签名验证工具_js实现微信公众号签名算法
微信公众号的签名一般是服务器后端完成的,但有时候我们要调用官方jssdk里面的一些分享、图像、扫一扫等安全性要求不是很高的接口时,其实可以前端直接签名调用。本文为大家分享一下前端js实现微信公众号签名算法。
一.参数排序
参数按字母排序并连接起来
(这里的三个入参只是示例演示,大家调用的时候请修改成正确的)
var inJsTicket = 'ticket';
var inNoncestr = 'abcdefghijklmnop';
var inTimestamp = '1506304549';
var url = 'http://abc.com';
var str = 'jsapi_ticket=' + inJsTicket + '&noncestr=' + inNoncestr + '×tamp=' +
inTimestamp + '&url=' + url;
二.调用sha1
var chrsz = 8;
var hexcase = 0;
var b64pad = '';
function hexSha1(s) {
return binb2hex(core_sha1(str2binb(s), s.length * chrsz));
}
function binb2hex(binarray) {
var hex_tab = hexcase ? '0123456789ABCDEF' : '0123456789abcdef';
var str = '';
for (var i = 0; i < binarray.length * 4; i++) {
str += hex_tab.charAt((binarray[i >> 2] >> ((3 - i % 4) * 8 + 4)) & 0xF) + hex_tab.charAt((binarray[i >> 2] >> ((3 - i % 4) * 8)) & 0xF);
}
return str;
}
function str2binb(str) {
var bin = [];
var mask = (1 << chrsz) - 1;
for (var i = 0; i < str.length * chrsz; i += chrsz) {
bin[i >> 5] |= (str.charCodeAt(i / chrsz) & mask) << (24 - i % 32);
}
return bin;
}
function core_sha1(x, len) {
/* append padding */
x[len >> 5] |= 0x80 << (24 - len % 32);
x[((len + 64 >> 9) << 4) + 15] = len;
var w = new Array(80);
var a = 1732584193;
var b = -271733879;
var c = -1732584194;
var d = 271733878;
var e = -1009589776;
for (var i = 0; i < x.length; i += 16) {
var olda = a;
var oldb = b;
var oldc = c;
var oldd = d;
var olde = e;
for (var j = 0; j < 80; j++) {
if (j < 16) {
w[j] = x[i + j];
} else {
w[j] = rol(w[j - 3] ^ w[j - 8] ^ w[j - 14] ^ w[j - 16], 1);
}
var t = safe_add(safe_add(rol(a, 5), sha1_ft(j, b, c, d)), safe_add(safe_add(e, w[j]), sha1_kt(j)));
e = d;
d = c;
c = rol(b, 30);
b = a;
a = t;
}
a = safe_add(a, olda);
b = safe_add(b, oldb);
c = safe_add(c, oldc);
d = safe_add(d, oldd);
e = safe_add(e, olde);
}
return [a, b, c, d, e];
}
function safe_add(x, y) {
var lsw = (x & 0xFFFF) + (y & 0xFFFF);
var msw = (x >> 16) + (y >> 16) + (lsw >> 16);
return (msw << 16) | (lsw & 0xFFFF);
}
function rol(num, cnt) {
return (num << cnt) | (num >>> (32 - cnt));
}
function sha1_kt(t) {
return (t < 20) ? 1518500249 : (t < 40) ? 1859775393 : (t < 60) ? -1894007588 : -899497514;
}
function sha1_ft(t, b, c, d) {
if (t < 20) {
return (b & c) | ((~b) & d);
} else if (t < 40) {
return b ^ c ^ d;
} else if (t < 60) {
return (b & c) | (b & d) | (c & d);
} else {
return b ^ c ^ d;
}
}
var signature = hexSha1(str);
输出结果为:af23c80b33b2420eb52bcb60f99f62f9b40cddd2
三.比较官网在线校验工具结果
获取的签名结果是一致的
前端微信签名验证工具_js实现微信公众号签名算法相关推荐
- ➢ 微信公众号运营教程(三)熟悉一些实用的工具 编写第一篇公众号推文
➢ 微信公众号运营教程(三) 熟悉一些实用的工具 & 编写第一篇公众号推文 实用的一些工具 ①浏览器:Google Chrome谷歌浏览器 ②图片素材 首先,我们编写文章的时候,需要一些配图, ...
- 多账号批量登录微信公众号工具_微众公众号助手
多账号批量登录微信公众号工具_微众公众号助手 账号登录工具 微信公众号 多账号批量登录微信公众号工具 微众公众号助手 点退出会自动退出登录的账号 左表选中下一个账号
- 微信小程序获取并展示公众号推文
微信小程序获取并展示公众号推文 获取公众号access_token(开发环境) IP白名单设置 获取access_token 小程序前端展示 素材导入云数据库 云函数读取展示 注:笔者是小程序菜鸟,代 ...
- 微信小程序生态13-微信公众号自定义菜单、个性化菜单配置
文章导航 微信小程序生态1-初识小程序 微信小程序生态2-创建一个微信小程序 微信小程序生态3-微信小程序登录流程设计 微信小程序生态4-扫普通二维码进入小程序.打开短链接进入小程序 微信小程序生态5 ...
- 历史 微信开发者工具_不用微信开发者工具也能调试微信页面
一般调试微信页面的时候,我们都会按照微信开发的官网教程,让你去安装微信开发者工具,然后在微信开发者工具上调试, 这样有时候会不会感觉很麻烦? 而且这个工具还经常卡死. 1515737321133.jp ...
- php公众号交友源码_个性定制微信导航源码,PHP公众号导航源码,含手机wap版,微信数据...
程序采用PHP5+MYSQL做为技术基础进行开发.2 z# c2 u. j" A 带数据,带手机版,PC版风格全网首发,大气. F h; \( x- E k7 y 程序含数 ...
- 最新微信ipad协议, CODE获取 公众号授权等
最新微信ipad协议,可实现微信80%功能:支持62数据登录.扫码登录.收发朋友圈.查看朋友圈.微信建群.微信拉人进群.关注公众号.微信消息收发.微信附近的人定位.微信添加好友.微信红包接收.消息收发 ...
- QQ群文件无法正常显示/微信(PC)电脑端公众号文章打开后显示一片空白的解决办法
QQ群文件无法正常显示/微信(PC)电脑端公众号文章打开后显示一片空白的解决办法: [解决办法] 1.打开ie浏览器,右上角类似齿轮的图标,找到Internet选项,打开 2.找到局域网设置 3.把下 ...
- java获取openid_JAVA获取微信小程序openid和获取公众号openid,以及通过openid获取用户信息...
https://www.cnblogs.com/lxwt/p/10154540.html?tdsourcetag=s_pcqq_aiomsg 一,首先说明下这个微信的openid 为了识别用户,每个用 ...
最新文章
- 程序运行慢?你怕是写的假 Python
- 在网页中画Icon小图标
- IE下Ajax 提交中文乱码问题
- 【总结】百家稷学!重点汇总有三AI(教育)服务过的那些企业与学校
- PHP的file_put_contents函数把一个字符串写入文件中
- pandas的DataFrame转化为Datatable的DataFrame
- IE9以及IE9以下,无法执行innerHTML这一操作的解决方法
- 亚马逊标题自动抓取_15分钟内开始使用Amazon Web Services和全自动资源调配
- itools 不支持缩略图下载_PS插件缩略图3.8.0.96安装教程
- java堆栈类在哪个包里_Java堆栈Stack类的使用
- matlab strel
- 员工主动辞职公司也要支付经济补偿金的17种情况
- 不用static,巧用对象.方法调用java中的函数
- LayaAir 事件处理器 Handler
- 计算机找不到链接打印机主机,电脑连接打印机厂商型号没有怎么办
- 高一计算机组装与维护教学总结,计算机优秀个人教学总结
- 非系统盘根目录出现Msdia80.dll文件如何处理
- IT项目经理面试题分解
- 美团2021届秋季校园招聘笔试真题解析:小美的跑腿代购
- 获取取本月一号、本月月末 日期