我很难理解我在这里做错了什么。
我正在尝试编写一些东西来加密进出 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 个字节之间。(虽然有些也可能很大,但大多数不是)
有什么建议么?
(我是节点新手,所以我提前为任何愚蠢道歉!)