🔍 Rétro-ingénierie logicielle
🔄 La rétro-ingénierie de logiciels est un processus qui consiste à récupérer la conception, les spécifications des exigences et les fonctionnalités d'un produit en analysant son code. Ce processus crée une base de données des programmes et génère des informations à partir de celle-ci. Cet article se concentre sur la rétro-ingénierie en détail.
❓ Qu'est-ce que la rétro-ingénierie ?
🔧 La rétro-ingénierie peut extraire des informations de conception à partir du code source, mais le niveau d'abstraction, l'exhaustivité de la documentation, la coopération entre les outils et l'analyste humain, ainsi que la directionnalité du processus varient considérablement.
🎯 Objectifs de la rétro-ingénierie :
- 💰 Réduction des coûts : La rétro-ingénierie peut aider à réduire les coûts de développement en trouvant des alternatives rentables pour les systèmes ou les composants.
- 🔒 Analyse de la sécurité : Utilisée en cybersécurité pour examiner les exploits, les vulnérabilités et les logiciels malveillants, aidant ainsi à comprendre les menaces et à développer des défenses pratiques.
- 🔄 Intégration et personnalisation : Permet aux développeurs d'incorporer ou de modifier des composants dans des systèmes existants pour améliorer leur fonctionnement ou les adapter à des besoins spécifiques.
- 🔧 Récupération du code source perdu : Utilisée pour récupérer ou produire une représentation de haut niveau du code source d'une application logicielle inaccessible.
- 🐛 Correction des bugs et maintenance : Aide à trouver et réparer les défauts ou à fournir des mises à jour pour les systèmes mal documentés.
- 🧩 Gérer la complexité : Utilisée pour comprendre et contrôler la complexité des systèmes en révélant leur architecture, leurs relations et leurs modèles de conception.
- 🔍 Récupérer les informations perdues : Vise à récupérer le maximum d'informations possibles lorsque le code source ou la documentation est perdu.
- ⚙️ Détecter les effets secondaires : Analyse les effets secondaires, les implications et les interactions imprévues d'un système ou d'un composant.
- 📊 Synthèse avec abstraction supérieure : Abstraction des fonctionnalités de bas niveau pour construire des représentations de niveau supérieur, facilitant la compréhension du système.
- ♻️ Faciliter la réutilisation : Identifie des pièces ou modules réutilisables dans des systèmes existants pour améliorer l'efficacité du développement.
🔍 Rétro-ingénierie pour comprendre les données :
🔢 La rétro-ingénierie des données se produit à différents niveaux d'abstraction et est souvent la première tâche de réingénierie.
- 🔧 Au niveau du programme : Les structures de données internes doivent être rétroconçues pour une réingénierie globale.
- 🌐 Au niveau du système : Les structures de données globales doivent être repensées pour s'adapter à de nouveaux paradigmes de gestion de bases de données.
🔄 Rétro-ingénierie pour comprendre le traitement :
⚙️ Comprendre le traitement commence par une tentative d'extraire les abstractions procédurales du code source. Chaque niveau d'abstraction (système, programme, composant, modèle, instruction) est analysé pour créer des diagrammes fonctionnels et des récits de traitement.
🛠️ Étapes de la rétro-ingénierie logicielle :
- 🔍 Collecte d'informations : Rassemble toutes les informations possibles sur le logiciel.
- 📄 Examen des informations : Étudie les informations recueillies pour se familiariser avec le système.
- 📊 Extraction de la structure : Identifie la structure du programme sous forme d'organigramme.
- 📝 Enregistrement des fonctionnalités : Documente les détails de chaque module de la structure.
- 📈 Enregistrement du flux de données : Dérive des diagrammes de flux de données pour montrer le flux entre les processus.
- 🔀 Enregistrement du flux de contrôle : Documente la structure de contrôle de haut niveau du logiciel.
- 🔍 Examen de la conception extraite : Vérifie la cohérence et l'exactitude du document de conception extrait.
- 📚 Génération de la documentation : Produit une documentation complète pour une utilisation future.
🔧 Outils de rétro-ingénierie :
⚙️ Les outils de rétro-ingénierie acceptent le code source en entrée et produisent des conceptions structurelles, procédurales, de données et comportementales. Quelques exemples d'outils incluent :
- 🌐 CIAO et CIA : Navigateur graphique pour les référentiels de logiciels et Web et collection d'outils de rétro-ingénierie.
- 🔍 Rigi : Outil de compréhension visuelle des logiciels.
- 🧩 Bunch : Outil de clustering/modularisation de logiciels.
- 🔧 GEN++ : Générateur d'applications pour le développement d'outils d'analyse pour le langage C++.
- 📚 PBS : Bibliothèque de logiciels pour extraire et visualiser l'architecture des programmes.