Aller au contenu

Autour d'un mot de passe⚓︎

Source

Liaison avec le BO

en classe de première :
- Type simple : parcours de chaîne de caractère
- Notion de force brute
- Dictionnaires par clés et valeurs

A quoi sert un mot de passe ?⚓︎

Accès à des services en ligne grâce au contrôle d’accès.
Imputabilité, preuve de qui a fait quoi.
Traçabilité des actions, historique des actions.

Exemple,
télédéclaration de l’impôt : imputabilité = lien entre la déclaration et la personne ET traçabilité = connaître l’heure et la date de la déclaration.

un mot de passe, c'est⚓︎

• La connaissance 👉 JE CONNAIS
• La possession 👉 JE POSSEDE
• Les caractéristiques biométriques 👉 JE SUIS

source : https://www.apog.net/deploiement-solution-mfa-indispensable

Les risques⚓︎

Divulgation :

  • Par négligence : faiblesse d’une personne, support amovible, diffusion à un tiers.
  • Par un service non sécurisé : protocoles https, imaps, pop3s, etc… à privilégier.
  • Par l’utilisation d’un vecteur infecté.
  • Mot de passe enregistré sans protection.

Malveillance :

  • Authentification sur un service illégitime.
  • Attaque par ingénierie sociale, piège.
  • Attaque par force brute ou divulgation d’une base de données mal sécurisée.

• Ces deux cas de figure peuvent entraîner :

  • La compromission des messages personnels.
  • La destruction de données.
  • La publication de messages ou photos préjudiciables sur les réseaux sociaux par exemple.
  • Des achats.
  • Des virements bancaires.

Craquer un mot de passe⚓︎

  • Par force brute
  • Par dictionnaire, en général avant l’attaque par force brute
  • Par permutation en échangeant des caractères (exemple : E par 3 ou O par 0).

Mais un souci de temps⚓︎

une image plutôt qu'un long discours :

temps de craquage par force brute d'un mdp

Comment construire un mot de passe fort ?⚓︎

Le mot de passe doit apporter un niveau de sécurité suffisant, c’est-à-dire difficile à découvrir par un attaquant dans un temps raisonnable à l’aide d’outils automatisés de recherche qui mettent en oeuvre les différentes techniques d’attaque. Il doit être composé au minimum de 10 caractères et ceux-ci doivent être de tout type.

Préconisations ANSI

Créez un mot de passe suffisamment long, complexe et inattendu : de 8 caractères minimum et contenant des minuscules, des majuscules, des chiffres et des caractères spéciaux. source

Quelques astuces : - Grâce à une phrase de passe avec des mots concaténés. - Par phonétique. - Les premières lettres des mots d’une phrase, citation, chanson, etc… - Mixer les trois méthodes.

Activité Phrase de passe

Point de programme : Manipulation de chaîne de caractère

🔽 Télécharger le notebook Activité correspondant ici
🔽 Télécharger le notebook Activité corrigé ici

idée : Poursuivre sur la conversion binaire.

Les rainbows Tables⚓︎

À quoi sert une Rainbow Table ?⚓︎

Une Rainbow Table est un fichier volumineux contenant une multitude de mots de passe reliés à leur valeur de hachage (empreinte).

illustration hachage

Les cybercriminels s’en servent pour cracker des mots de passe. Les Rainbow Tables permettent généralement de réduire le temps et la mémoire nécessaires à l’attaque, contrairement aux attaques par force brute qui requièrent beaucoup de temps et aux attaques par dictionnaires qui nécessitent beaucoup de mémoire.

À noter que les Rainbow Table peuvent également être utilisées par des experts en cybersécurité pour identifier des failles ou effectuer des tests de sécurité.

Comment fonctionne une Rainbow Table ?⚓︎

Lors de la génération d’une Table arc-en-ciel, chaque mot de passe est haché (le procédé peut être répété plusieurs fois en fonction des cas).

Seul le mot de passe initial et la valeur finale sont conservés dans la Table. Ce processus est ensuite répété à partir de nouveaux mots de passe, jusqu’à obtenir une Table importante.

Pour cracker un mot de passe, le cybercriminel va chercher son empreinte dans la Table arc-en-ciel. Une fois trouvée, il peut donc récupérer le mot de passe initial de cette empreinte.

Activité

Point de programme : Manipulation de dictionnaire et CSV

🔽 Télécharger le notebook Activité correspondant ici

Stockage d'un mot de passe⚓︎

La règle de "base" en hygiène de codeur est de ne JAMAiS stocké un mot de passe en clair, que ce soit dans un fichier ou pire dans une base de données. Un site ne doit jamais être en capacité de vous communiquer votre mot de passe initial !

Le seul moment où un mot de passe est en clair est quand il est saisi dans le champ du formulaire.
Imaginons ... Si tous les sites avaient tous la même méthode de chiffrement (MD5 ou SH256) et qu'un utilisateur utilisait le même mot de passe sur tous ces sites ...

Il existe des fuites de données recensant le couple identifiant/mot de passe d'un grand nombre de personne !
Vous pouvez tester votre adresse mail sur le site ';--have i been pwned? pour savoir si celle ci appartient à une fuite de données connue.

Mise en exemple :
Alphonse (al@mail.com) utilise le mot de passe "secret" pour les sites monsite.fr et concurrent.fr
Chacun des deux sites utilise la même méthode de chiffrement MD5.
Donc chacun des deux sites possèdent dans sa base le couple al@mail.com et 5ebe2294ecd0e0f08eab7690d2a6ee69.
monsite.fr subit une attaque et une fuite de données massive.
le pirate possède donc le moyen de se connecter à concurrent.fr avec le compte d'alphonse...

C'est la que l'on introduit la notion de salage.

Définition : Le salage est un procédé utilisé en cryptographie pour renforcer la sécurité des mots de passe stockés. Il consiste à ajouter une valeur aléatoire unique (appelée "sel" ou "salt") à chaque mot de passe avant de le hacher. Cela rend plus difficile pour les attaquants d'utiliser des attaques par table arc-en-ciel ou par dictionnaire, car même si deux utilisateurs ont le même mot de passe, leurs hashs seront différents grâce aux sels uniques.

🐍 Python
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
import hashlib

# generate new salt, hash password
# h est le sel qui sera utilisé pour le hachage
h = b"monsite.fr"
# Hash du mot de passe classique sans salage
pwd_md5 = hashlib.md5(b"secret").hexdigest()
print(pwd_md5)
# Hash du mot de passe classique avec salage
pwd = hashlib.pbkdf2_hmac('md5', b"secret", h, 100000)
print(pwd)
📋 Texte
5ebe2294ecd0e0f08eab7690d2a6ee69
b'\xc3;K\xc2\xfb\xb4z\xca`f\xc4T\xc9I\x1b.'

Activité possible

A la suite de la sensibilisation sur les mots de passe, faire réaliser aux élèves une infographie à destination de leurs camarades lycéens non sensibilisés.

infographies réalisées par des élèves de première NSI, 2024