AES encryption of 16 bytes without padding

后端 未结 2 619
忘掉有多难
忘掉有多难 2021-01-20 04:21

This should be a simple question, but I can\'t find any examples or figure out the answer from the openssl docs.

I want to encrypt exactly 128 bits,

2条回答
  •  广开言路
    2021-01-20 04:49

    AES encryption of 16 bytes without padding

    Use the EVP_* interfaces and disable padding on the block.

    Use the EVP_* interface because it supports engines and hardware acceleration, like AES-NI. The AES_encrypt functions are software based and do not support alternate implementations. Also, its not readily apparent, but AES_encrypt is not portable - some platforms suffer endianess issues.

    You need to call EVP_CIPHER_CTX_set_padding to ensure no padding is added. From the EVP_CIPHER_CTX_set_padding(3) man page:

    EVP_CIPHER_CTX_set_padding() enables or disables padding. By default encryption operations are padded using standard block padding and the padding is checked and removed when decrypting. If the pad parameter is zero then no padding is performed, the total amount of data encrypted or decrypted must then be a multiple of the block size or an error will occur. This function should be called after the context is set up for encryption or decryption with EVP_EncryptInit_ex().

    So your steps are:

    1. Call EVP_CIPHER_CTX_new to create a context
    2. Call EVP_EncryptInit_ex with the context
    3. Call EVP_CIPHER_CTX_set_padding on the context
    4. Call EVP_EncryptUpdate_ex to encrypt the data
    5. Call EVP_EncryptFinal_ex to retrieve the cipher text

    Also see EVP Symmetric Encryption and Decryption on the OpenSSL wiki.

提交回复
热议问题