我有一些API需要使用php中的gzencode函数加密的符号,现在我需要使用nodejs制作测试工具来测试这些API。
我在nodejs中尝试过pako
和zlib
模块,但是压缩结果始终与php不同,所以我想知道如何在像gzencode这样的nodejs中获得相同的压缩结果在php7中?
const pako = require('pako');
const zlib = require('zlib');
const crypto = require('crypto');
const input = '1234';
zlib.gzip(input, (err, buffer) => {
if (!err) {
console.log("--------zlib result---------");
console.log(buffer.toString());
console.log("");
console.log("length: " + buffer.toString().length);
console.log("md5: " + crypto.createHash('md5').update(buffer.toString()).digest("hex"));
}
});
var result = pako.gzip(input, { to: 'string' });
console.log("--------pako result---------");
console.log(result);
console.log("");
console.log("length: " + result.length);
console.log("md5: " + crypto.createHash('md5').update(result).digest("hex"));
$str = gzencode('1234');
var_dump($str);
var_dump(strlen($str));
var_dump(md5($str));
3426 £àã
length: 24
md5: 45461056d1301798aae739d467b1811b
3426 ���
length: 23
md5: ea90ab1d16e5596020fb313119879e26<br/>
string(24) "3426"
int(24)
string(32) "cbe26958c184e607833efbf9b63516fb"
答案 0 :(得分:0)
这是一个有点棘手的诊断方法,但幸运的是,最终的解决方法很小:
代替:
crypto.createHash('md5').update(buffer.toString()).digest("hex"));
我们将仅使用缓冲区对象本身进行更新:
crypto.createHash('md5').update(buffer).digest("hex"));
所以更新后的代码是:
const zlib = require('zlib');
const crypto = require('crypto');
const input = '1234';
zlib.gzip(input, (err, buffer) => {
if (!err) {
console.log("--------Zlib result---------");
console.log("buffer (hex): ", buffer.toString("hex"));
console.log("");
console.log("length: " + buffer.length);
console.log("md5: " + crypto.createHash('md5').update(buffer).digest("hex"));
}
});
现在,Node.js和PHP代码都将产生md5输出:
cbe26958c184e607833efbf9b63516fb
对于输入('1234')。
如上所述,这可能取决于平台。