- Fuzzing
-
Le fuzzing est une technique pour tester des logiciels. L'idée est d'injecter des données aléatoires dans les entrées d'un programme. Si le programme échoue (par exemple en crashant ou en générant une erreur), alors il y a des défauts à corriger. Exemples de point d'entrée d'un programme :
- Fichiers
- Périphériques (clavier, souris, etc.)
- Variable d'environnement
- Réseau
- Limitation des ressources (mémoire, disque dur, temps CPU, etc.)
- etc.
Le grand avantage du fuzzing est que l'écriture de tests est extrêmement simple, ne demande aucune connaissance du fonctionnement du système et permet de trouver des vulnérabilités facilement. D'ailleurs, le fuzzing est également utilisé pour traquer des failles de sécurité ou dans la rétro-ingénierie.
La première trace du fuzzing est la publication datant du 12 décembre 1990 : « An Empirical Study of the Reliability of UNIX Utilities » [1] écrite par Barton P. Miller, Lars Fredriksen, et Bryan So. Le résumé indique que durant les essais ils ont été capables de crasher 25 à 33% des programmes utilitaires de n'importe quelle version d'UNIX ». Le rapport présente les outils de test mais également l'origine des erreurs.
Le fuzzing est tellement simple à utiliser et efficace pour trouver des vulnérabilités que le chercheur en sécurité informatique Charlie Miller a refusé de dévoiler les vulnérabilités zero day trouvées dans le code de logiciels célèbres (contrairement au règlement du concours de sécurité informatique Pwn2own), afin de protester contre les éditeurs qui n'utilisent pas assez cette technique simple selon lui[1].
Inversement au fuzzing qui est une méthode de test par boîte noire, la méthode de test par boîte blanche analyse un système dont on connaît exactement le fonctionnement.
Références
- (fr)Pwn2Own : un hacker refuse de dévoiler à Adobe, Microsoft et Apple leurs failles, par Christophe Auffray (ZDNet France), le 26 mars 2010
Liens externes
- (en) Site sur le fuzzing de l'Université de Wisconsin, propose notamment le résultat d'analyse de tests de fuzzing sur plusieurs logiciels courants.
- (en) Microsoft's Secure Development Process utilise le fuzzing
- (en) The Bulletproof Penguin : Tests de fuzzing sous Linux
- (en) fuzz : outil de fuzzing pour Linux
- (en) Folklore.org sur "MonkeyLives" : Tests de fuzzing sur le Macintosh original
- (en) Digital Dwarf Society propose des fuzzings fonctionnels, des exemples de code et des ressources intéressantes sur les techniques de fuzzing
Catégories :- Test logiciel
- Audit logiciel
- Procédure de sécurité informatique
Wikimedia Foundation. 2010.