【问题标题】:Produce same result as CryptoJS.enc.Base64 using PHP使用 PHP 生成与 CryptoJS.enc.Base64 相同的结果
【发布时间】:2016-06-25 11:53:25
【问题描述】:

我有一个 javascript 函数,我正在尝试将其转换为 PHP,它使用 CryptoJS 库,特别是 components/enc-base64-min.jsrollups/md5.js。他们可以找到here

就是这段代码

// Let's say str = 'hello';

var md5 = CryptoJS.MD5(str);
md5 = md5.toString(CryptoJS.enc.Base64);
// md5 outputs "XUFAKrxLKna5cZ2REBfFkg=="

我假设str 变量是使用 md5 散列然后编码为 Base64,所以我尝试了这个简单的代码

$md5 = md5($str);
$md5 = base64_encode($md5);
// md5 outputs "MmZjMGE0MzNiMjg4MDNlNWI5NzkwNzgyZTRkNzdmMjI="

然后我尝试验证两个输出,看起来 JS 输出甚至不是有效的 Base64 字符串。

为了进一步理解,我试图从W3Schools 中寻找toString() 参数,但这对我来说没有意义,根据引用,参数应该是整数(2、8 或 16),那么为什么是用CryptoJS.enc.Base64 代替吗?

我的目标不是使用 JS 生成有效的 base64 编码字符串,而是使用 PHP 生成相同的输出。

【问题讨论】:

  • MD5 产生一个 16 字节的二进制输出。 Base 64 将每个 6 位编码为一个 8 位 ASCII 字符。 16*8/6 = 21.3 字节,Base64 将输出填充为 4 字节倍数。这个 MD5 输出 base64 编码将产生 24 字节的输出,这与第一个示例一致。第二个示例产生 44 字节的输出,因此不正确。
  • @zaph 感谢您的详细说明

标签: javascript php cryptography cryptojs


【解决方案1】:

带有单个参数的 php 的 md5() 返回 md5 哈希作为十六进制字符串

相反,您希望将原始字节编码为 Base64,因此您必须将可选参数 $raw_output 也传递给 md5()(设置为 true

$md5 = md5($str, true);

http://php.net/manual/it/function.md5.php

【讨论】:

    猜你喜欢
    • 2011-01-22
    • 1970-01-01
    • 2020-06-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-12-24
    相关资源
    最近更新 更多