Protection contre les injections SQL : échapper aux guillemets simples et envelopper les entrées de l'utilisateur n'est pas une bonne idée
Dans le monde de la sécurité SQL, il est crucial d'empêcher les injections malveillantes susceptibles de détruire l'intégrité des données. Bien que les requêtes SQL paramétrées soient la méthode préférée pour nettoyer les entrées utilisateur, certains développeurs peuvent envisager d'utiliser une méthode qui implique d'échapper des guillemets simples et d'entourer l'entrée entre guillemets simples. Cependant, cette technique s'est révélée inefficace pour plusieurs raisons :
La fuite n'est pas assez complète
Bien que cette méthode soit conçue pour empêcher les utilisateurs de terminer des chaînes avec des guillemets simples échappés, elle ne parvient pas à résoudre les autres vulnérabilités d'injection SQL. Les barres obliques inverses peuvent toujours échapper aux guillemets simples, permettant à un attaquant de continuer la chaîne et potentiellement d'exécuter des commandes malveillantes.
Vérification de la liste noire et vérification de la liste blanche
La validation de la liste noire, comme l'échappement de caractères spécifiques, est problématique car elle repose sur l'identification des entrées interdites. Cependant, il est presque impossible de prédire toutes les entrées potentiellement malveillantes. La validation de la liste blanche, en revanche, définit clairement les valeurs acceptables, garantissant que seules les données autorisées sont saisies dans le système.
Meilleure technologie d'atténuation
Au lieu de vous fier à l'échappement manuel et à la mise sur liste noire, utilisez des techniques éprouvées et fiables pour atténuer les attaques par injection SQL :
Conclusion
Échapper aux guillemets simples et aux entrées utilisateur environnantes entre guillemets simples est un moyen inadéquat d'empêcher l'injection SQL. Appuyez-vous sur des requêtes paramétrées, des objets de commande et de paramètre, des procédures stockées, des listes blanches et des autorisations de base de données pour sécuriser vos applications SQL.
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!