Maison >développement back-end >Golang >Comment valider les mots de passe dans Go sans revenir en arrière sur les expressions régulières ?

Comment valider les mots de passe dans Go sans revenir en arrière sur les expressions régulières ?

Linda Hamilton
Linda Hamiltonoriginal
2024-11-03 16:55:291012parcourir

How to Validate Passwords in Go Without Backtracking Regular Expressions?

Validation des mots de passe avec des expressions régulières dans Go

La validation des mots de passe à l'aide d'expressions régulières est une tâche courante, mais le package d'expressions régulières fourni par le standard de Go L'API diffère de celles des autres langues. Ainsi, si vous essayez de créer une fonction de validation de mot de passe avec des expressions régulières, vous risquez de rencontrer des défis uniques.

Les règles de mot de passe

Les règles de mot de passe fournies nécessitent que les mots de passe :

  • Comprennent au moins 7 lettres.
  • Incluent au moins 1 chiffre.
  • Contient au moins 1 caractère majuscule.
  • Comportez au moins 1 caractère spécial.

Limites de Regex

Malheureusement, il est essentiel de noter que la mise en œuvre de toutes ces règles à l'aide d'une seule expression régulière dans Go est pas réalisable. En effet, les expressions régulières de Go ne prennent pas en charge le retour en arrière, qui est nécessaire pour garantir que les caractères sont présents et comptés dans la chaîne du mot de passe.

Une approche alternative

Compte tenu de ces limites, une approche alternative est nécessaire. Une option consiste à créer une fonction personnalisée qui vérifie ces règles à l'aide d'une série de vérifications :

<code class="go">func verifyPassword(s string) (sevenOrMore, number, upper, special bool) {
    letters := 0
    for _, c := range s {
        switch {
        case unicode.IsNumber(c):
            number = true
        case unicode.IsUpper(c):
            upper = true
            letters++
        case unicode.IsPunct(c) || unicode.IsSymbol(c):
            special = true
        case unicode.IsLetter(c) || c == ' ':
            letters++
        default:
            // Handle the case if there are invalid characters.
        }
    }
    sevenOrMore = letters >= 7
    return
}</code>

Cette fonction parcourt la chaîne du mot de passe, vérifiant la présence de lettres, de chiffres, de caractères majuscules et de caractères spéciaux. . Il renvoie des valeurs booléennes indiquant si chaque condition a été remplie. En combinant ces vérifications, vous pouvez mettre en œuvre efficacement les règles de validation des mots de passe sans recourir aux expressions régulières.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn