我正在编写一个大量使用密码学的应用程序。与大多数网络应用程序一样,我的应用程序将数据分解为不同类型的消息(即时消息、文件块、视频帧等)——并且必须检查每个消息的真实性,以防篡改和正确的来源。到目前为止,我可以使用 ECDH 来协商我已经用于 AES 的共享密钥。当然,以后可以使用相同的共享密钥。
我的问题是:在这种情况下,使用 ECDSA 来签署每条消息,而不是简单地使用 ECDH 与 HMAC 建立的共享密钥,是否有任何额外的好处?
下面,当我说 M 时,我指的是加密消息或明文;没关系。请更正以下任何错误。
我知道在 ECDSA(或 DSA)中,通常M
使用安全散列算法(我目前正在使用 SHA-2 之一)对消息()进行散列H(M)
,然后H(M)
使用签名者的私钥对消息进行加密。这会产生R
和S
整数(签名)。然后,M、R 和 S 被发送给已经拥有发送者公钥的接收者。 H'(M)
计算,并使用R
和验证签名S
。BouncyCastle 提供了ECDSASigner
实现这一点的方法。
在 HMAC 中,我需要一个共享密钥。然后:(
HMAC(K, M) := H( f2(K) || H(f1(K) || M) )
感谢 Paŭlo Ebermann 的更正。有关详细信息,请参阅他的答案。)
那么,考虑到 DH/ECDH 安全地协商共享密钥,我是否有理由不使用 HMAC?
相关:为什么NSA为 DSA 而不是 MAC 指定标准算法?仅仅因为它可以是 SHA-2 + AES?
速度在这里很重要,因为我希望我正在制作的这个协议不仅现在支持文本消息,而且在不久的将来也支持大文件和视频帧。因此,我更喜欢使用 HMAC,但想确保我能达到上述目标。
谢谢你的帮助!