我正在运行 Sharepoint 2007 场并尝试计算用户权限。我已阅读有关我从中获取掩码的特定元数据字段的这篇文章。我一直在查看以下指南,以了解我需要比较哪些面具。
这是我的 delima,每当我在 IE javascript 控制台中运行以下代码时,我都会返回 0:
((0x4000000000000000).toString(16) & (0x400001F07FFF1BFF).toString(16))
现在我知道这是不正确的,因为相应的二进制值是:
100000000000000000000000000000000000000000000000000000000000000
100000000000000000000011111000001111111111111110001101111111111
哪个应该等于
100000000000000000000000000000000000000000000000000000000000000
我也将它放入我的 Windows 计算器中,以确保我没有发疯(并获得那些超长的二进制数)。
注意 当我到达这一行时,我意识到我的浏览器是 32 位的(这是我使用它的网站的要求),这是一个 64 位的数字!
如何(最好在一行中)使用 32 位浏览器计算两个 64 位数字的按位与?
我知道我可以将数字转换为二进制字符串并利用循环来检查每一位,但有没有更简单的方法?
编辑 - 解决方案 利用这篇文章中的信息和下面的答案,我想出了以下解决方案:
var canEdit = false;
var canEditMask = [0x00000000,0x00000004];
var canApprove = false;
var canApproveMask = [0x00000000,0x00000010];
var canRead = false;
var canReadMask = [0x00000000,0x00000001];
var canDesign = false;
var canDesignMask = [0x00000000,0x00000800];
var mask = [originalmask.substring(0,10).toString(16),
("0x"+itemperms.substring(9)).toString(16)];
canEdit = (mask[0] & canEditMask[0]) >0 || (mask[1] & canEditMask[1]) >0;
canRead = (mask[0] & canReadMask[0]) >0 || (mask[1] & canReadMask[1]) >0;
canDesign = (mask[0] & canDesignMask[0]) >0 || (mask[1] & canDesignMask[1]) >0;
canApprove = (mask[0] & canApproveMask[0]) >0 || (mask[1] & canApproveMask[1]) >0;