C++ - 在没有加密大小的情况下解密
C++ - Decrypting without encryption size
我找了一段时间也没有找到解决这个问题的方法。我正在使用 BCryptDecrypt 来解密我的加密数据,但它需要 EncryptedData 的大小,你如何在不知道大小的情况下解密?
我知道 BCryptEncrypt 会在成功加密数据后为您提供长度,我知道的唯一方法是将其与加密数据/IV 一起发送。
例如:假设我要加密数据,然后通过带有 IV 的套接字将其发送到将解密数据的 WinSock 服务器。该服务器如何在不知道大小的情况下解密它?即使它知道密钥和 IV。
谢谢
如果需要尺寸,我看到两种获取方式:
- 将其与加密数据一起显式发送。
- 在服务器端缓冲所有数据,直到完全接收。跟踪您收到的字节数。
首先,您可以尝试这样的操作:
<number of bytes to follow><separator symbol><message data>
其次要求您能够正确检测到消息的结尾。您可以通过特定的消息结束序列检测到这一点。然而,如果出现的话,您需要在消息中转义这样的序列。类似于 C/C++/Java/C#... 中字符的转义方式 如果不选择第一种方法,这对我来说是最简单的,这就是我可能更喜欢下面的变体。 ..
另一种方法可能是在消息完成后关闭连接。然后,但是,您需要检测连接是否定期关闭或是否断开,因为在后一种情况下,您不能尝试解码...
您甚至可以将这两种方法结合起来:
<message start sequence>
<number of bytes to follow>
<separator symbol>
<encrypted data>
<message end sequence>
消息开始序列和消息结束序列都必须转义。如果您在加密数据中检测到消息开始序列,或者在读取字节数之前检测到消息结束序列,您就会知道在服务器端出现了严重错误...
我找了一段时间也没有找到解决这个问题的方法。我正在使用 BCryptDecrypt 来解密我的加密数据,但它需要 EncryptedData 的大小,你如何在不知道大小的情况下解密?
我知道 BCryptEncrypt 会在成功加密数据后为您提供长度,我知道的唯一方法是将其与加密数据/IV 一起发送。
例如:假设我要加密数据,然后通过带有 IV 的套接字将其发送到将解密数据的 WinSock 服务器。该服务器如何在不知道大小的情况下解密它?即使它知道密钥和 IV。
谢谢
如果需要尺寸,我看到两种获取方式:
- 将其与加密数据一起显式发送。
- 在服务器端缓冲所有数据,直到完全接收。跟踪您收到的字节数。
首先,您可以尝试这样的操作:
<number of bytes to follow><separator symbol><message data>
其次要求您能够正确检测到消息的结尾。您可以通过特定的消息结束序列检测到这一点。然而,如果出现的话,您需要在消息中转义这样的序列。类似于 C/C++/Java/C#... 中字符的转义方式 如果不选择第一种方法,这对我来说是最简单的,这就是我可能更喜欢下面的变体。 ..
另一种方法可能是在消息完成后关闭连接。然后,但是,您需要检测连接是否定期关闭或是否断开,因为在后一种情况下,您不能尝试解码...
您甚至可以将这两种方法结合起来:
<message start sequence>
<number of bytes to follow>
<separator symbol>
<encrypted data>
<message end sequence>
消息开始序列和消息结束序列都必须转义。如果您在加密数据中检测到消息开始序列,或者在读取字节数之前检测到消息结束序列,您就会知道在服务器端出现了严重错误...