Maison > développement back-end > C++ > le corps du texte

Comment pouvez-vous effacer en toute sécurité les données sensibles stockées dans une « std :: string » ?

Susan Sarandon
Libérer: 2024-10-25 14:09:30
original
568 Les gens l'ont consulté

How Can You Securely Clear Sensitive Data Stored in a `std::string`?

Effacement sécurisé des données sensibles dans std::string

Le stockage de données sensibles, telles que les mots de passe, en mémoire nécessite des mécanismes d'effacement sécurisés pour empêcher fuites de mémoire potentielles. Alors que les tableaux char* proposent l'API SecureZeroMemory à cet effet, l'utilisation de std::string soulève la question de la mise en œuvre d'une solution similaire.

Défis avec std::string

Une tentative a été faite pour créer un allocateur personnalisé qui remet à zéro la mémoire en toute sécurité lors de la désallocation :

<code class="cpp">namespace secure {
  template <class T> class allocator : public std::allocator<T> {...}
}</code>
Copier après la connexion

Cependant, il a été découvert que cet allocateur n'est pas toujours invoqué pour les petites chaînes, laissant potentiellement des données sensibles exposées.

Solution : évitez d'utiliser std::string pour les données sensibles

La conclusion est que std::string, tel qu'actuellement défini, n'est pas adapté au stockage de données sensibles. Des implémentations personnalisées ou des structures de données alternatives doivent être envisagées à cet effet spécifique.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!