Is the result of a RSA encryption guaranteed to be random

前端 未结 1 1482
礼貌的吻别
礼貌的吻别 2021-01-25 08:01

I use RSACryptoServiceProvider to encrypt some small blocks of data. For the solution I\'m working on, it\'s important that if the same piece of source data is encrypted twice w

1条回答
  •  感情败类
    2021-01-25 09:02

    The text-book RSA encryption algorithm is deterministic:

    ciphertext = plaintext ^ encryption-exponent  mod  modulus
    

    (Here ^ is integer exponentiation, mod the remainder operation.)

    But as you remarked, this does not provide a good security guarantee, as an attacker which can guess the plaintext can simply verify this guess by encrypting it himself and comparing the results.

    For this reason, the official RSA specifications (and also all implementations used in practice) include some (partly random) padding, so we don't actually encrypt plaintext, but pad(plaintext):

    ciphertext = pad(plaintext) ^ encryption-exponent  mod  modulus
    

    Decryption:

    plaintext = unpad( ciphertext ^ decryption-exponent mod modulus )
    

    Only with this padding RSA is actually a secure encryption scheme.

    A similar padding is also used for RSA signatures, to avoid easy forging of signatures.

    0 讨论(0)
提交回复
热议问题