常用的openssl函数

本文介绍了openssl中常用的函数,重点讨论了base64解编码过程,包括EVP_DecodeInit(), EVP_DecodeUpdate(), EVP_DecodeFinal()的使用,以及一次性解编码函数EVP_EncodeBlock()和EVP_DecodeBlock()的应用。同时,文章还详细讲解了AES加解密,特别是AES_set_encrypt_key()用于设置加密密钥,AES_ecb_encrypt()用于执行ECB模式的加密操作。" 88864837,7394762,UART数据接收与校验处理,"['嵌入式开发', '通信协议', '数据处理']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

常用的openssl函数

base64解编码

  1. 依次调用EVP_DecodeInit(), EVP_DecodeUpdate(), EVP_DecodeFinal(),与md5和sha1类似,适用于数据量特别大时,分段解码,通过多次调用EVP_DecodeUpdate()实现。
  2. 调用int EVP_EncodeBlock(unsigned char *t, const unsigned char *f, int n);
    int EVP_DecodeBlock(unsigned char *t, const unsigned char *f, int n);这两个函数都是一次性使用的,注意下返回值是解码后的结果长度,因此返回值大于等于0时,解编码成功。
bool base64Decode(const string& strSrc, string& strDest)
{
    char* szBuffer = new char[strSrc.length()];
    if (EVP_DecodeBlock((unsigned char*)szBuffer, (const unsigned char*)strSrc.c_str(), strSrc.length()) <= 0)
    {
        return false;
    }
    strDest = szBuffer;
    delete[] szBuffer;
    szBuffer = NULL;
}

AES加解密

AES加解密最关键的函数:

加密

int AES_set_encrypt_key(const unsigned char *userKey, const int bits, AES_KEY *key);
将密钥初始化成AES_KEY结构,注意第二个参数是bit数,而不是字节数。

void AES_ecb_encrypt(const unsigned char *in, unsigned char *out, const AES_KEY *key, const int enc);

//sKey是经过base64编码过的key,如果key没有经过base64
int AesEncryptEcb(const string &sKey, const string &sSrc, string &sDst)
{
    int nRet;

    //base64解码
    string sAesKey;
    if ((nRet = DecodeBase64(sKey, sAesKey)) != CK_OK)
        return nRet;

    const unsigned int uKeySize = static_cast<unsigned int>(sAesKey.size());
    if (uKeySize != 16 && uKeySize != 24 && uKeySize != 32) //必须是 128/192/256 bits
        return CK_AESKYE_Invalid;

    //初始化key
    AES_KEY key;
    AES_set_encrypt_key(reinterpret_cast<const unsigned char*>(sAesKey.data()),
                        static_cast<int>(8 * uKeySize),
                        &key);

    //追加padding, PKCS7方式
    size_t padding = uKeySize - sSrc.size() % uKeySize;
    string sCopy(sSrc);
    sCopy.append(padding, static_cast<char>(padding));

    //分组加密
    std::vector<unsigned char> sRst(sCopy.size());
    for (size_t i = 0; i < sCopy.size(); i += AES_BLOCK_SIZE)
    {
        AES_ecb_encrypt(reinterpret_cast<const unsigned char *>(sCopy.data() + i), &sRst[i], &key, AES_ENCRYPT);
    }

    sDst.assign(sRst.begin(), sRst.end());
    return CK_OK;
}

//------------------------------------------------------------------------------
int AesDecryptEcb(const string &sKey, const string &sSrc, string &sDst)
{
    int nRet;

    //base64解码
    string sAesKey;
    if ((nRet = DecodeBase64(sKey, sAesKey)) != CK_OK)
        return nRet;

    const unsigned int uKeySize = static_cast<unsigned int>(sAesKey.size());
    if (uKeySize != 16 && uKeySize != 24 && uKeySize != 32) //必须是 128/192/256 bits
        return CK_AESKYE_Invalid;

    //初始化key
    AES_KEY key;
    AES_set_decrypt_key(reinterpret_cast<const unsigned char*>(sAesKey.data()),
                        static_cast<int>(8 * uKeySize),
                        &key);

    //解密
    std::vector<unsigned char> sRst(sSrc.size());
    for (size_t i = 0; i < sSrc.size(); i += AES_BLOCK_SIZE)
    {
        AES_ecb_encrypt(reinterpret_cast<const unsigned char *>(sSrc.data() + i), &sRst[i], &key, AES_DECRYPT);
    }

    //去掉padding
    const size_t pads = sRst[sRst.size() - 1];
    if (pads > 0 && pads <= uKeySize && ((sRst.size() - pads) > 0))
    {
        sDst.assign(sRst.begin(), sRst.end() - pads);
        return CK_OK;
    }

    return CK_AESData_Invalid;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值