Как шифровать данные в c++?

Пользователь

от sherwood_littel , в категории: C/C++ , год назад

Как шифровать данные в c++?

Facebook Vk Ok Twitter LinkedIn Telegram Whatsapp

2 ответа

Пользователь

от edyth , год назад

@sherwood_littel 

В C++ есть различные способы для шифрования данных, но некоторые из наиболее распространенных включают использование симметричного шифрования, асимметричного шифрования и хэш-функций.

  1. Симметричное шифрование: Одним из самых распространенных методов симметричного шифрования является шифр AES (Advanced Encryption Standard). Для использования шифра AES вам понадобится подключить заголовочный файл
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#include 

std::string encryptAES(const std::string& plainText, const std::string& key) {
    AES_KEY aesKey;
    AES_set_encrypt_key((unsigned char*)key.c_str(), 128, &aesKey);

    unsigned char iv[AES_BLOCK_SIZE];
    memset(iv, 0x00, AES_BLOCK_SIZE);

    std::string cipherText;
    const size_t length = plainText.length();

    for (size_t i = 0; i < length; i += AES_BLOCK_SIZE) {
        unsigned char inBlock[AES_BLOCK_SIZE];
        unsigned char outBlock[AES_BLOCK_SIZE];

        memset(inBlock, 0x00, AES_BLOCK_SIZE);

        size_t blockSize = std::min(AES_BLOCK_SIZE, length - i);
        memcpy(inBlock, plainText.c_str() + i, blockSize);

        AES_encrypt(inBlock, outBlock, &aesKey);

        cipherText.append((char*)outBlock, AES_BLOCK_SIZE);
    }

    return cipherText;
}

std::string decryptAES(const std::string& cipherText, const std::string& key) {
    AES_KEY aesKey;
    AES_set_decrypt_key((unsigned char*)key.c_str(), 128, &aesKey);

    std::string plainText;
    const size_t length = cipherText.length();

    for (size_t i = 0; i < length; i += AES_BLOCK_SIZE) {
        unsigned char inBlock[AES_BLOCK_SIZE];
        unsigned char outBlock[AES_BLOCK_SIZE];

        memset(inBlock, 0x00, AES_BLOCK_SIZE);

        memcpy(inBlock, cipherText.c_str() + i, AES_BLOCK_SIZE);

        AES_decrypt(inBlock, outBlock, &aesKey);

        plainText.append((char*)outBlock, AES_BLOCK_SIZE);
    }

    return plainText;
}


  1. Асимметричное шифрование: Одним из самых распространенных методов асимметричного шифрования является шифр RSA. В C++ вы можете использовать библиотеки, такие как OpenSSL или Crypto++. Эти библиотеки предоставляют функции шифрования и расшифровки RSA. Пример кода для шифрования и дешифрования с использованием шифра RSA с использованием библиотеки Crypto++:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include 
#include 
#include 
#include 

std::string encryptRSA(const std::string& plainText, const CryptoPP::RSA::PublicKey& publicKey) {
    CryptoPP::AutoSeededRandomPool rng;

    CryptoPP::RSAES_OAEP_SHA_Encryptor encryptor(publicKey);
    std::string cipherText;

    CryptoPP::StringSource(plainText, true,
        new CryptoPP::PK_EncryptorFilter(rng, encryptor,
            new CryptoPP::StringSink(cipherText)
        )
    );

    return cipherText;
}

std::string decryptRSA(const std::string& cipherText, const CryptoPP::RSA::PrivateKey& privateKey) {
    CryptoPP::AutoSeededRandomPool rng;

    CryptoPP::RSAES_OAEP_SHA_Decryptor decryptor(privateKey);
    std::string recoveredText;

    CryptoPP::StringSource(cipherText, true,
        new CryptoPP::PK_DecryptorFilter(rng, decryptor,
            new CryptoPP::StringSink(recoveredText)
        )
    );

    return recoveredText;
}

int main() {
    CryptoPP::AutoSeededRandomPool rng;

    CryptoPP::RSA::PrivateKey privateKey;
    privateKey.GenerateRandomWithKeySize(rng, 1024);

    CryptoPP::RSA::PublicKey publicKey(privateKey);

    std::string plainText = "Hello, world!";
    std::string cipherText = encryptRSA(plainText, publicKey);

    std::cout << "Cipher text: " << CryptoPP::base64_encode((const unsigned char*)cipherText.c_str(), cipherText.length()) << std::endl;

    std::string recoveredText = decryptRSA(cipherText, privateKey);

    std::cout << "Recovered text: " << recoveredText << std::endl;

    return 0;
}


  1. Хэш-функции: Хэш-функции преобразуют информацию в хэш-код фиксированного размера. Одной из наиболее распространенных хэш-функций является SHA-256 (Secure Hash Algorithm 256-bit). В C++ вы можете использовать библиотеки, такие как OpenSSL или Crypto++, для вычисления хэш-кода с использованием SHA-256. Пример кода для вычисления SHA-256 хэша в библиотеке Crypto++:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
#include 
#include 
#include 

std::string hashSHA256(const std::string& input) {
    CryptoPP::SHA256 hash;
    std::string digest;

    CryptoPP::StringSource(input, true,
        new CryptoPP::HashFilter(hash,
            new CryptoPP::StringSink(digest)
        )
    );

    return digest;
}

int main() {
    std::string input = "Hello, world!";
    std::string hash = hashSHA256(input);

    std::cout << "SHA-256 hash: " << CryptoPP::HexEncoder(new CryptoPP::StringSink(std::cout)).Put((const unsigned char*)hash.c_str(), hash.length()) << std::endl;

    return 0;
}


Это лишь несколько примеров способов шифрования данных в C++. Существуют и другие алгоритмы шифрования и библиотеки, которые можно использовать для защиты данных в C++. Важно помнить, что безопасность данных является сложной темой, и рекомендуется обратиться к специалисту в области криптографии или безопасности для получения более глубокого понимания искусства безопасности данных.

Пользователь

от leila.dickinson , 7 месяцев назад

@sherwood_littel 

Если у вас возникнут дополнительные вопросы или вам потребуется помощь с конкретным аспектом шифрования в C++, не стесняйтесь задавать вопросы. Буду рад помочь!