Does encryption guarantee integrity?

前端 未结 3 1961
春和景丽
春和景丽 2021-01-31 09:57

To build a secure system, can we assume that encryption guarantees integrity is true before starting a secure programming?

  • Both in symmetric and public-key encrypt
3条回答
  •  死守一世寂寞
    2021-01-31 10:39

    No. This is easy to see if you consider the one-time pad, a simple (theoretically) perfectly secure system.

    If you change any bit of the output, a bit of the clear text will change, and the recipient has no way to detect this.

    This is an obvious case, but the same conclusion applies to most encryption systems. They only provide for confidentiality, not integrity.

    Thus, you may want to add a digital signature. Interestingly, when using public key cryptography, it is not sufficient to sign then encrypt (SE), or to encrypt then sign (ES). Both of these are vulnerable to replay attacks. You have to either sign-encrypt-sign or encrypt-sign-encrypt to have a generally secure solution. This paper explains why in detail.

    If you use SE, the recipient can decrypt the message, then re-encrypt it to a different recipient. This then deceives the new recipient about the sender's intended recipient.

    If you use ES, an eavesdropper can remove the signature and add their own. Thus, even though they can't read the message, they can take credit for it, pretending to be the original sender.

提交回复
热议问题