微信公众号的签名一般是服务器后端完成的,但有时候我们要调用官方jssdk里面的一些分享、图像、扫一扫等安全性要求不是很高的接口时,其实可以前端直接签名调用。本文为大家分享一下前端js实现微信公众号签名算法。

一.参数排序

参数按字母排序并连接起来

(这里的三个入参只是示例演示,大家调用的时候请修改成正确的)

var inJsTicket = 'ticket';

var inNoncestr = 'abcdefghijklmnop';

var inTimestamp = '1506304549';

var url = 'http://abc.com';

var str = 'jsapi_ticket=' + inJsTicket + '&noncestr=' + inNoncestr + '&timestamp=' +

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实现微信公众号签名算法相关推荐

  1. ➢ 微信公众号运营教程(三)熟悉一些实用的工具 编写第一篇公众号推文

    ➢ 微信公众号运营教程(三) 熟悉一些实用的工具 & 编写第一篇公众号推文 实用的一些工具 ①浏览器:Google Chrome谷歌浏览器 ②图片素材 首先,我们编写文章的时候,需要一些配图, ...

  2. 多账号批量登录微信公众号工具_微众公众号助手

    多账号批量登录微信公众号工具_微众公众号助手 账号登录工具 微信公众号 多账号批量登录微信公众号工具 微众公众号助手 点退出会自动退出登录的账号 左表选中下一个账号

  3. 微信小程序获取并展示公众号推文

    微信小程序获取并展示公众号推文 获取公众号access_token(开发环境) IP白名单设置 获取access_token 小程序前端展示 素材导入云数据库 云函数读取展示 注:笔者是小程序菜鸟,代 ...

  4. 微信小程序生态13-微信公众号自定义菜单、个性化菜单配置

    文章导航 微信小程序生态1-初识小程序 微信小程序生态2-创建一个微信小程序 微信小程序生态3-微信小程序登录流程设计 微信小程序生态4-扫普通二维码进入小程序.打开短链接进入小程序 微信小程序生态5 ...

  5. 历史 微信开发者工具_不用微信开发者工具也能调试微信页面

    一般调试微信页面的时候,我们都会按照微信开发的官网教程,让你去安装微信开发者工具,然后在微信开发者工具上调试, 这样有时候会不会感觉很麻烦? 而且这个工具还经常卡死. 1515737321133.jp ...

  6. php公众号交友源码_个性定制微信导航源码,PHP公众号导航源码,含手机wap版,微信数据...

    程序采用PHP5+MYSQL做为技术基础进行开发.2 z# c2 u. j" A 带数据,带手机版,PC版风格全网首发,大气. F  h; \( x- E  k7 y        程序含数 ...

  7. 最新微信ipad协议, CODE获取 公众号授权等

    最新微信ipad协议,可实现微信80%功能:支持62数据登录.扫码登录.收发朋友圈.查看朋友圈.微信建群.微信拉人进群.关注公众号.微信消息收发.微信附近的人定位.微信添加好友.微信红包接收.消息收发 ...

  8. QQ群文件无法正常显示/微信(PC)电脑端公众号文章打开后显示一片空白的解决办法

    QQ群文件无法正常显示/微信(PC)电脑端公众号文章打开后显示一片空白的解决办法: [解决办法] 1.打开ie浏览器,右上角类似齿轮的图标,找到Internet选项,打开 2.找到局域网设置 3.把下 ...

  9. java获取openid_JAVA获取微信小程序openid和获取公众号openid,以及通过openid获取用户信息...

    https://www.cnblogs.com/lxwt/p/10154540.html?tdsourcetag=s_pcqq_aiomsg 一,首先说明下这个微信的openid 为了识别用户,每个用 ...

最新文章

  1. 程序运行慢?你怕是写的假 Python
  2. 在网页中画Icon小图标
  3. IE下Ajax 提交中文乱码问题
  4. 【总结】百家稷学!重点汇总有三AI(教育)服务过的那些企业与学校
  5. PHP的file_put_contents函数把一个字符串写入文件中
  6. pandas的DataFrame转化为Datatable的DataFrame
  7. IE9以及IE9以下,无法执行innerHTML这一操作的解决方法
  8. 亚马逊标题自动抓取_15分钟内开始使用Amazon Web Services和全自动资源调配
  9. itools 不支持缩略图下载_PS插件缩略图3.8.0.96安装教程
  10. java堆栈类在哪个包里_Java堆栈Stack类的使用
  11. matlab strel
  12. 员工主动辞职公司也要支付经济补偿金的17种情况
  13. 不用static,巧用对象.方法调用java中的函数
  14. LayaAir 事件处理器 Handler
  15. 计算机找不到链接打印机主机,电脑连接打印机厂商型号没有怎么办
  16. 高一计算机组装与维护教学总结,计算机优秀个人教学总结
  17. 非系统盘根目录出现Msdia80.dll文件如何处理
  18. IT项目经理面试题分解
  19. 美团2021届秋季校园招聘笔试真题解析:小美的跑腿代购
  20. 获取取本月一号、本月月末 日期

热门文章

  1. 2022中级Android开发面试解答,当上项目经理才知道
  2. 手机广告 开源SNS
  3. 驼峰命名法【规约与实践】
  4. 有什么软件可以编译汇编程序?
  5. SAMBA 基础及实战
  6. Pycharm 报错 Environment location directory is not empty 解决
  7. #{}和${}的使用
  8. sqlserver错误码
  9. c语言中左移和乘法谁高级,C程序员说使用移位运算代替乘法和除法更有效,是真的吗?...
  10. idea 设置某个单词不显示下划线