1

我试图从头开始编写Adler-32 哈希函数只是为了找点乐子,我已经完成了它,除了每次我散列一个字符串时,它总是缺少前面的零。我已经阅读了数十次公式和 Adler-32 描述,但我无法弄清楚为什么我的代码会产生它。代码如下。

function toAdler32(str) {

    if (typeof str != "string") throw new Error('HashUtil: Data passed to Hash function was not of type String.');

    let A16 = 1;
    let B16 = 0;

    for (let i = 0; i < str.length; i++) {

        A16 += (str.charCodeAt(i)) % 65521;
        B16 += A16 % 65521;
    }

    return ((B16 << 16) | A16).toString(16);
}

console.log(toAdler32('test'));

// Returns `45d01c1` when it should return `045d01c1`.
4

1 回答 1

1

您需要用 0 填充它 - 它正在删除前导 0,因为前导 0 在数字中毫无意义,无论基数为 10 还是基数为 16...

如果你有 100 张卡片,你不会说你有 0100 张卡片,因为你不需要前导 0。

如果您希望字符串具有一定的长度,请对其进行零填充:

如何用前导零填充值?

于 2020-11-19T02:31:07.000 回答