基于openssl的3DES(ECB)加密算法

项目中需要用到就找了下,借鉴网上的一些代码,在加上自己的改良,得到了现在的代码,也解决了我的需求。

附openssl安装教程 https://blog.csdn.net/qq_39805297/article/details/100532833

先说下,3DES加密算法有几种填充方式,比如zeropadding、pkcs5padding、pkcs7padding等等,我使用的pkcs7padding的填充方式,比较普遍的算法,而且也是可以与java端契合的填充方式。

#pragma once
#include <iostream>
#include <string.h>
#include <openssl/des.h>

class C3DES 
{
public:
    /******************* 加密:strin是需要加密的明文,strkey是密钥 *********************/
    static std::string encrypt(std::string strin, std::string strkey)
    {
        std::string ret;
        int docontinue = 1;
        const char *data = strin.c_str(); /* 明文 */
        int data_len;
        int data_rest;
        unsigned char ch;
        unsigned char *src = NULL; /* 补齐后的明文 */
        unsigned char *dst = NULL; /* 加密后的明文 */
        int len;
        unsigned char tmp[8];
        unsigned char in[8];
        const char *k = strkey.c_str(); /* 原始密钥 */
        int key_len;
#define LEN_OF_KEY 24
        unsigned char key[LEN_OF_KEY]; /* 补齐后的密钥 */
        unsigned char block_key[9];
        DES_key_schedule ks, ks2, ks3;
        /* 构造补齐后的密钥 密钥需要24位 不足24位的用0x00补齐*/
        key_len = strlen(k);
        memcpy(key, k, key_len);
        memset(key + key_len, 0
3DES(Triple Data Encryption Algorithm)是一种对称加密算法,是DES(Data Encryption Standard)算法的改进版本。其基本原理是将数据经过三次DES加密运算,以增加加密强度。 以下是3DES加密算法的简单源码示例(使用C语言): ```c #include <stdio.h> #include <stdlib.h> #include <openssl/des.h> void tripleDesEncrypt(const unsigned char* plaintext, const unsigned char* key, unsigned char* ciphertext) { DES_cblock key1, key2, key3; DES_key_schedule ks1, ks2, ks3; // 将原始密钥按需求分为3份,如果密钥长度不够,可以通过填充等方式进行处理 memcpy(key1, key, 8); memcpy(key2, key+8, 8); memcpy(key3, key+16, 8); // 设置3个子密钥 DES_set_key_unchecked(&key1, &ks1); DES_set_key_unchecked(&key2, &ks2); DES_set_key_unchecked(&key3, &ks3); // 进行三次DES加密运算 DES_ecb3_encrypt(plaintext, ciphertext, &ks1, &ks2, &ks3, DES_ENCRYPT); } int main() { unsigned char plaintext[] = "Hello, World!"; unsigned char key[] = "abcdefghabcdefghabcdefgh"; unsigned char ciphertext[16]; // 3DES加密结果为64位(8字节) tripleDesEncrypt(plaintext, key, ciphertext); printf("CipherText: %s\n", ciphertext); return 0; } ``` 这段示例代码使用了OpenSSL库中的DES函数。首先,我们将原始密钥分为三个8字节的子密钥;然后,使用这三个子密钥依次对明文进行DES加密运算。最终得到的密文为长度为8字节的数据。 注意:以上代码只是简单示例,实际使用中需要考虑更多的安全性和实现细节。另外,由于DES算法的弱密钥问题,实际应用中更常用的是AES等更强大的加密算法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值