0

我很难理解我在这里做错了什么。

我正在尝试编写一些东西来加密进出 TCP 套接字的数据,但我正在努力从加密密码流中获取任何输出。

示例:(精简以使其尽可能简单)

加密 = 要求('加密');


data.copy(cipherKey,0,5,133); //缓冲区填充了 128 字节的密码数据。(为了简单起见,去掉了数据源)
//test value (in hex bytes) of cipherKey = abcecfa8c752b72d784db7ddbc30db7da2b22ba7eab9000f2615e26d55a6b27f1ad97239151e1b6398afa055e347571aa018332bef041d032b73e5c23e48407d1e288f8c8edcadd6a70f6f1031cf4778b037b8beaed4863d5ac2e6f4cf454a87ece5051a49d11a2b9a89bf955cbf54a22f05405c43f20f4d4bf26bd2e928189d

var credentials = { 算法:“aes128”,密码:cipherKey.toString() };

var decipher = crypto.createDecipher(credentials.algorithm, credentials.password);
var cipher = crypto.createCipher(credentials.algorithm, credentials.password);

cipher.pipe(process.stdout);

cipher.write("你好!");

通过重复 cipher.write("Hello!"); ,我确实设法获得了一些输出(虽然很少);行大约 10 次,这让我想知道您是否必须在“触发”某些输出之前输入最少数量的数据。

如果这是问题所在,那么我需要找到一种解决方法,因为大多数需要通过它的数据包将在 4 到 32 个字节之间。(虽然有些也可能很大,但大多数不是)

有什么建议么?

(我是节点新手,所以我提前为任何愚蠢道歉!)

4

1 回答 1

3

是的,这里有缓冲。只需让您的加密流知道不会再有任何数据,它就会自行刷新。

在您的示例中,只需添加

cipher.end()
于 2013-11-04T06:28:20.383 回答