2013-03-12 75 views
4

我写了一个数据加密工具,它可以在mac os上运行,但不能在ubuntu上运行。 以下代码显示了差异。nodejs cipher ubuntu没有按预期工作

var crypto = require('crypto'); 

var k = '123456789'; 
var v = '123456789'; 
var alg = 'AES-128-CBC'; 


var buf = new Buffer('Hello world!'); 
console.log(buf); 

var cipher = crypto.createCipheriv(alg, k, v); 
var result = cipher.update(buf); 
result += cipher.final(); 
buf = new Buffer(result, 'binary'); 
console.log(buf); 

var decipher = crypto.createDecipheriv(alg, k, v); 
decipher.setAutoPadding(auto_padding=false); 
result = decipher.update(buf); 
result += decipher.final(); 
buf = new Buffer(result, 'binary'); 

console.log(buf); 
console.log(buf.toString()); 

输出,在Mac上:

<Buffer 48 65 6c 6c 6f 20 77 6f 72 6c 64 21> 
<Buffer 17 0e 2d 73 94 bf d4 24 95 b3 a7 49 73 58 5e 3f> 
<Buffer 48 65 6c 6c 6f 20 77 6f 72 6c 64 21 04 04 04 04> 
Hello world! 

Ubuntu的:

<Buffer 48 65 6c 6c 6f 20 77 6f 72 6c 64 21> 
<Buffer 17 0e 2d 73 fd fd fd 24 fd fd fd 49 73 58 5e 3f> 
<Buffer 05 6d 69 fd fd 1b 49 62 60 39 fd 68 fd fd fd> 
mi��Ib`9�h��� 

什么想法? thx

+0

我不能在ubuntu中重现。我运行的Ubuntu 12.04,节点0.8,一切都很好。你的系统设置是什么? – matehat 2013-03-12 15:37:50

+0

我可以在Debian上使用节点0.10.0在i386和x86_64平台上重现它。这听起来像它可能是一个过时的OpenSSL库(我的机器都不是最新的)。 – robertklep 2013-03-12 15:43:22

+0

上次我检查了crypto API页面,它是3 - 表,但现在页面读取稳定性:2 - 不稳定。所以你应该使用节点0.8或等到它们稳定。 – user568109 2013-03-12 17:06:10

回答

3

节点0.10.0引入了对crypto模块的一些内部更改,这可能会破坏现有的代码。

用下面的修补程序(如http://nodejs.org/api/crypto.html#crypto_recent_api_changes建议),它的工作原理我的Debian机器上:

var crypto = require('crypto'); 
crypto.DEFAULT_ENCODING = 'binary'; 
... 

(!感谢@ user568109让我阅读的页面)

上述页面还提出建议以永久修复您的代码,因为设置crypto.DEFAULT_ENCODING被认为是一种临时措施。

+1

(刚刚检查过,Mac上的节点0.10.0原始代码也失败) – robertklep 2013-03-12 17:36:30