JS通过位运算实现权限加解密
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了JS通过位运算实现权限加解密,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1249字,纯文字阅读大概需要2分钟。
内容图文
![JS通过位运算实现权限加解密](/upload/InfoBanner/zyjiaocheng/336/f969342e0a8449f0b472f41d0b7a5692.jpg)
首先介绍一下js中的位运算:
1. "&" :与运算,转化为二进制数,如果相同位数都为1则得结果为1,否则为0;
2. "|" :或运算,转化为二进制数,如果相同位数只要有一个为1则得结果为1,否则为0;
3. "^" :异或运算,转化为二进制数,如果相同位数不同则得结果为1,否则为0;
4."<<" 异位运算符,1<<1,表示将1左移一位,也就是010,在二进制中代表2;
顺便说一下,十进制数字互相转化。
十进制转为别的进制:
var num = 123; console.log(num.toString(2)) console.log(num.toString(8))//参数传想要转化的位数
别的进制转化为十进制:
var num = 110; console.log(parseInt(num,2))//二进制转化为十进制
假设我们现在有5项权限,在二进制中用1代表拥有权限,0代表不拥有。所以11111这样代表拥有所有的五项权限,那么我们如何知道用户是否有某一项具体权限呢。
比如,我们现在想检测用户是否有第一项权限,我们首先用过异位 1 << 0,向左移0位,还是1,然后1 & (Math.pow(2,5) -1),
如果返回0,说明个位对不上,也就是说我们当前没有权限,如果返回1,说明我们拥有第一项权限,同理,如果需要检验第二位权限,只需要异位2就好了。
if((1 << 0) & (Math.pow(2,5) - 1) !== 0){ //拥有第一项权限权限 } if((1 << 1) & (Math.pow(2,5) - 1) !== 0){ //拥有第一项权限权限 }
总结
以上所述是小编给大家介绍的JS通过位运算实现权限加解密,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
内容总结
以上是互联网集市为您收集整理的JS通过位运算实现权限加解密全部内容,希望文章能够帮你解决JS通过位运算实现权限加解密所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。