Heim >Backend-Entwicklung >C++ >Wie verwaltet und schützt man sensible Daten in C++?
In C++ können Sie vertrauliche Daten verwalten und schützen, indem Sie Bibliotheken wie OpenSSL oder libsodium zur Verschlüsselung verwenden; die Bibliothek fmtlib zur Datenmaskierung verwenden; Lagerung.
So verwalten und schützen Sie sensible Daten in C++
Der Schutz sensibler Daten in C++ ist von entscheidender Bedeutung, da er unbefugten Zugriff, Diebstahl oder Datenverlust verhindert. In diesem Tutorial erfahren Sie, wie Sie Ihre Daten effektiv verwalten und schützen, einschließlich praktischer Beispiele.
1. Verschlüsselung
Verschlüsselung ist eine der effektivsten Möglichkeiten, Ihre Daten zu schützen. Mithilfe von Algorithmen werden sensible Daten in ein unverständliches Format umgewandelt. Für die Verschlüsselung stehen in C++ mehrere Bibliotheken zur Verfügung, beispielsweise OpenSSL und libsodium.
#include <openssl/aes.h> int main() { // 生成随机密钥 unsigned char key[AES_KEY_SIZE]; RAND_bytes(key, AES_KEY_SIZE); // 初始化 AES 加密器 AES_KEY aes_key; AES_set_encrypt_key(key, AES_KEY_SIZE * 8, &aes_key); // 加密数据 unsigned char data[] = "Sensitive data"; unsigned char encrypted_data[AES_BLOCK_SIZE]; AES_encrypt(data, encrypted_data, &aes_key); // 解密数据 AES_decrypt(encrypted_data, data, &aes_key); return 0; }
2. Tokenisierung
Bei der Tokenisierung werden sensible Daten durch eine eindeutige Kennung oder ein Token ersetzt. Dieser Ansatz verringert die Angriffsfläche der Daten, da keine Speicherung der eigentlichen Daten erforderlich ist. Es gibt mehrere Tokenisierungsbibliotheken in C++, wie zum Beispiel boost::tokenizer.
#include <boost/tokenizer.hpp> int main() { // 定义令牌分隔符 const char delimiter = ','; // 原始数据 std::string original_data = "John Doe,123 Main Street,Anytown,CA"; // 创建令牌分隔符 boost::char_separator<char> sep(delimiter); // 令牌化数据 std::vector<std::string> tokens; boost::split(tokens, original_data, sep); // 输出令牌化数据 for (auto& token : tokens) { std::cout << token << std::endl; } return 0; }
3. Datenmaskierung
Datenmaskierung ist eine Technik, die sensible Daten maskiert, bevor sie angezeigt oder exportiert werden. Die fmtlib-Bibliothek kann in C++ zur Datenmaskierung verwendet werden.
#include <fmt/format.h> int main() { // 原始数据 std::string name = "John Doe"; std::string address = "123 Main Street"; // 掩盖姓氏 std::string masked_name = fmt::format("{0} ***", name); // 掩盖地址 std::string masked_address = fmt::format("*{0}", address); // 输出掩盖后的数据 std::cout << "Masked name: " << masked_name << std::endl; std::cout << "Masked address: " << masked_address << std::endl; return 0; }
4. Sichere Speicherung
Sichere Speichertechnologie sorgt dafür, dass sensible Daten sicher gespeichert werden, wie z. B. Key Manager oder Credential Repository. Auf den Schlüsselmanager kann in C++ über die Google Cloud KMS-Bibliothek zugegriffen werden.
#include <google/cloud/kms/v1/key_management_service_client.h> int main() { // 创建密钥管理器客户端 auto client = google::cloud::kms::v1::KeyManagementServiceClient( google::cloud::Options{} .set<google::cloud::UnifiedCredentialsOption>( google::cloud::MakeGoogleDefaultCredentials())); // 创建密钥名称 google::cloud::kms::v1::CryptoKeyName key_name( "projects/my-project", "locations/us-east1", "my-key"); // 获取密钥 auto key = client.GetCryptoKey(key_name); // 检查是否有错误 if (!key) throw std::move(key).status(); // 使用密钥进行操作 return 0; }
Das obige ist der detaillierte Inhalt vonWie verwaltet und schützt man sensible Daten in C++?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!