Maison >développement back-end >C++ >Conseiller en mots de passe forts
Chaque 7 mai, des organisations du monde entier rappellent aux utilisateurs l'importance de mots de passe forts. Selon le géant de la technologie Google
24% de leurs utilisateurs finaux utilisent le mot « mot de passe » ou « Qwerty » comme mot de passe de leur compte.
Cependant, seuls 34 % des utilisateurs changent fréquemment les mots de passe de leur compte.
Dans le monde technologiquement avancé d’aujourd’hui, chaque tentative de connexion est une attaque cybercriminelle potentielle. Mais de nombreuses personnes utilisent encore aujourd’hui des mots de passe faibles sur leurs comptes professionnels et personnels.
Ici, nous discuterons et vérifierons si le mot de passe créé est très faible, faible, moyen, fort ou très fort. Pour ce faire, nous vérifierons les critères de création de mots de passe selon les exigences de l'algorithme. Dans l'article d'aujourd'hui, nous apprendrons comment créer un outil de suggestion de mot de passe fort à l'aide du code C++.
Il s'agit d'un algorithme général pour les mots de passe forts. Il aide les développeurs à développer des systèmes de suggestion de mots de passe dans un environnement C++ et à trouver des critères spécifiques pour les mots de passe.
Étape 1 − Démarrer
Étape 2 - Le mot de passe idéal doit comporter au moins huit caractères.
Étape 3 − Doit contenir au moins un caractère numérique.
Étape 4 - Il doit y avoir au moins une lettre minuscule. [Exemple : a, b, c…, z]
Étape 5 - Il doit y avoir au moins une lettre majuscule. [Exemple : A, B, C..., Z]
Étape 6 - Il doit contenir au moins un caractère spécial. [Exemple : !@#$ %^&*()-+]
Étape 7 - La fin
switch (k) { case 1: if ((count_alphabet == 7) && (count_number == 0 || count_ALPHABET == 0 || count_ALPHABET == 7 || count_s_symbol == 0)) break; key = getKey(); password = password + alphabet[key]; count_alphabet++; count++; break; case 2: if ((count_ALPHABET == 7) && (count_number == 0 || count_alphabet == 0 || count_alphabet == 5 || count_s_symbol == 0)) break; key = getKey(); password = password + ALPHABET[key]; count_ALPHABET++; count++; break; case 3: if ((count_number == 7) && (count_alphabet == 0 || count_alphabet == 1 || count_ALPHABET == 3 || count_ALPHABET == 0 || count_s_symbol == 0)) break; key = getKey(); key = key % 10; password = password + number[key]; count_number++; count++; break; case 4: if ((count_s_symbol == 1) && (count_alphabet == 0 || count_alphabet == 1 || count_ALPHABET == 0 || count_ALPHABET == 1 || count_number == 0)) break; key = getKey(); key = key % 6; password = password + s_symbol[key]; count_s_symbol++; count++; break; } cout << "\n-----------------------------\n"; cout << " Enter The Password \n"; cout << "------------------------------\n\n"; cout << " " << password add here; cout << "\n\n Press any key continue \n"; getchar(); }
Dans cette syntaxe, la condition vérifie les exigences minimales pour un mot de passe idéal. Nous avons divisé chaque condition possible en quatre cas, en vérifiant si les exigences en matière de caractères alphabétiques, numériques et de symboles spéciaux sont remplies, et si les exigences minimales sont respectées. Pendant le traitement, s'il reste d'autres caractères, ils seront ignorés.
Méthode 1 - Créer un environnement de conseil en mot de passe solide
Méthode 2 - Vérifiez si le mot de passe est fort, faible ou moyen
Méthode 3 - Vérifiez si le mot de passe remplit les conditions
Dans ce code de construction C++, le système vérifiera la force des données d'entrée (mot de passe). Il analysera l'entrée pour trouver tous les critères mentionnés pour le mot de passe idéal. Si toutes les conditions sont réunies, alors c'est un mot de passe idéal. Sinon, tous les caractères manquent dans l'entrée et le mot de passe sera généré aléatoirement.
La traduction chinoise de#include <bits/stdc++.h> using namespace std; string add_more_char(string str, int need){ int pos = 0; string low_case = "abcdefghijklmno"; for (int a = 0; a < need; a++) { pos = rand() % str.length(); str.insert(pos, 1, low_case[rand() % 26]); } return str; } string suggester(int m, int o, int a, int d, string str) { string num = "0123456789"; string low_case = "abcdefghijklmno"; string up_case = "ABCDEFGHIJKLMNO"; string spl_char = "@#$_()!*&%#+-=.`"; int pos = 0; if (m == 0) { pos = rand() % str.length(); str.insert(pos, 1, low_case[rand() % 26]); } if (o == 0) { pos = rand() % str.length(); str.insert(pos, 1, up_case[rand() % 26]); } if (a == 0) { pos = rand() % str.length(); str.insert(pos, 1, num[rand() % 10]); } if (d == 0) { pos = rand() % str.length(); str.insert(pos, 1, spl_char[rand() % 7]); } return str; } void generate_password(int n, string p){ int l = 0, u = 0, d = 0, s = 0, need = 0; string suggest; for (int j = 0; j < n; j++) { if (p[j] >= 97 && p[j] <= 122) l = 1; else if (p[j] >= 65 && p[j] <= 90) u = 1; else if (p[j] >= 48 && p[j] <= 57) d = 1; else s = 1; } if ((l + u + d + s) == 4) { cout << "Hurra! Your Passcode Is Strong, Go Ahead!" << endl; return; } else cout << "Suggested password As Per The Input. Pick One For You! " << endl; for (int i = 0; i < 10; i++) { suggest = suggester(l, u, d, s, p); need = 8 - suggest.length(); if (need > 0) suggest = add_more_char(suggest, need); cout << suggest << endl; } } int main(){ string input_string = "abonirudra@1607"; srand(time(NULL)); generate_password(input_string.length(), input_string); return 0; }
Suggested password As Per The Input. Pick One For You! abonirudGra@1607 abConirudra@1607 abonirudra@1E607 abonirudra@16A07 abonirudra@160L7 abNonirudra@1607 aNbonirudra@1607 abonirDudra@1607 aboniruFdra@1607 abonirNudra@1607
Construisez du code basé sur l'algorithme ci-dessus et C++ ; encodez la chaîne pour vérifier la force d'entrée. La méthode entière renvoie « Strong » en sortie lorsque toutes les conditions sont remplies. Si seules les trois premières étapes sont remplies et que le mot de passe comporte au moins huit caractères, il renverra « Moyen ».
La traduction chinoise de#include <bits/stdc++.h> using namespace std; void printStrongNess(string& input) { int n = input.length(); bool hasLower = false, hasUpper = false; bool hasDigit = false, specialChar = false; string normalChars = "abcdefghijklmnopqrstu" "vwxyzABCDEFGHIJKL023456789 "; for (int i = 0; i < n; i++) { if (islower(input[i])) hasLower = true; if (isupper(input[i])) hasUpper = true; if (isdigit(input[i])) hasDigit = true; size_t special = input.find_first_not_of(normalChars); if (special != string::npos) specialChar = true; } cout << "Strength of password:-"; if (hasLower && hasUpper && hasDigit && specialChar && (n >= 8)) cout << "Strong" << endl; else if ((hasLower || hasUpper) && specialChar && (n >= 6)) cout << "Moderate" << endl; else cout << "Weak" << endl; } int main(){ string input = "Abonirudra@22052023"; printStrongNess(input); return 0; }
Strength of password:-Strong
Dans ce code, nous effectuerons une opération de vérification sur un mot de passe spécifique. Voici les étapes spécifiques -
Accepter les entrées de l'utilisateur.
La combinaison de mot de passe saisie par l'utilisateur sera désormais vérifiée.
Les mots de passe sont divisés en trois types : forts, moyens et faibles.
Si toutes les conditions sont remplies, ce sera un mot de passe fort.
Sinon, moyen ou faible.
#include <bits/stdc++.h> using namespace std; void checkpassword(string& password) { int n = password.length(); bool hasLower = false, hasUpper = false, hasDigit = false; for (int i = 0; i < n; i++) { if (islower(password[i])) hasLower = true; if (isupper(password[i])) hasUpper = true; if (isdigit(password[i])) hasDigit = true; } cout << "Strength of password you have entered as per the input :-"; if ( hasUpper && hasDigit && hasLower && (n >= 6)) cout << "Strong" << endl; else if ((hasLower || hasUpper) && hasDigit && (n >=6)) cout << "Moderate" << endl; else cout << "Weak" << endl; } int main() { cout << "Welcome To The Password Tester! Let's Check Your Password. " << endl; cout << "Let's consider the average length of an ideal strong password should be more than 6 character " << endl; cout << "Please enter your desired password with :- " << endl; cout << " * at least one upper case letter and lower case letter " << endl; cout << " * and also need to have at least one digit " << endl; string password; cout <<"Enter your monermoto password"<<endl; getline(cin,password); checkpassword(password); return 0; }
Welcome To The Password Tester! Let's Check Your Password. Let's consider the average length of an ideal strong password should be more than 6 character Please enter your desired password with :- * at least one upper case letter and lower case letter * and also need to have at least one digit Enter your monermoto password Strength of password you have entered as per the input :-Weak
À partir de cet article, nous avons appris comment créer un environnement de suggestion de mot de passe en utilisant C++, puis comment évaluer la qualité du mot de passe à l'aide de certaines étiquettes (fort, moyen, faible) sur cette plate-forme 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!