«Если рабочий хочет хорошо выполнять свою работу, он должен сначала заточить свои инструменты» — Конфуций, «Аналитики Конфуция. Лу Лингун»
титульная страница > программирование > Изучение надежности пароля и проверки номера в Perl и Go

Изучение надежности пароля и проверки номера в Perl и Go

Опубликовано 18 ноября 2024 г.
Просматривать:377

Exploring Password Strength and Number Validation in Perl and Go

В этой статье я рассмотрю две задачи из Perl Weekly Challenge #287: укрепление слабых паролей и проверка чисел. Я предоставлю решения обеих задач, продемонстрировав реализации на Perl и Go.

Оглавление

  1. Укрепление слабых паролей
  2. Проверка чисел
  3. Заключение

Укрепление слабых паролей

Первая задача — определить минимальное количество изменений, необходимых для повышения надежности пароля. Критерии надежного пароля:

  1. Содержит не менее 6 символов.
  2. Он содержит как минимум одну строчную букву, одну прописную букву и одну цифру.
  3. Не содержит трех последовательных одинаковых символов.

Примеры

  • Ввод: «a» → Выход: 5
  • Ввод: «aB2» → Выход: 3
  • Ввод: «PaaSW0rd» → Выход: 0
  • Ввод: «Paaasw0rd» → Выход: 1
  • Ввод: «ааааа» → Выход: 2

Решение

Perl-реализация

#!/usr/bin/perl
use strict;
use warnings;
use List::Util 'max';

# Function to count groups of three or more repeating characters
sub count_repeats {
    my ($str) = @_;
    my $repeats = 0;

    # Find repeating characters and count the required changes
    while ($str =~ /(.)\1{2,}/g) {
        $repeats  = int(length($&) / 3);
    }

    return $repeats;
}

# Function to calculate the minimum steps to create a strong password
sub minimum_steps_to_strong_password {
    my ($str) = @_;
    my $length = length($str);

    # Check if the password contains the required character types
    my $has_lower = $str =~ /[a-z]/;
    my $has_upper = $str =~ /[A-Z]/;
    my $has_digit = $str =~ /\d/;

    # Calculate the number of types needed
    my $types_needed = !$has_lower   !$has_upper   !$has_digit;
    my $repeats = count_repeats($str);

    # Return the minimum steps based on the length of the password
    return ($length 



Тесты реализации Perl

use strict;
use warnings;
use Test::More;
require "./ch-1.pl";

my @tests = (
    ["a", 5],
    ["aB2", 3],
    ["PaaSW0rd", 0],
    ["Paaasw0rd", 1],
    ["aaaaa", 2],
);

foreach my $test (@tests) {
    my ($input, $expected) = @$test;
    my $result = minimum_steps_to_strong_password($input);
    is($result, $expected, "Input: '$input'");
}

done_testing();

Перейти к реализации

package main

import (
    "regexp"
)

func countRepeats(password string) int {
    repeats := 0
    count := 1

    for i := 1; i  b {
        return a
    }
    return b
}

Тесты реализации Go

package main

import (
    "testing"
)

func TestMinimumStepsToStrongPassword(t *testing.T) {
    tests := []struct {
        password string
        expected int
    }{
        {"a", 5},
        {"aB2", 3},
        {"PaaSW0rd", 0},
        {"Paaasw0rd", 1},
        {"aaaaa", 2},
    }

    for _, test := range tests {
        result := minimumStepsToStrongPassword(test.password)
        if result != test.expected {
            t.Errorf("For password '%s', expected %d but got %d", test.password, test.expected, result)
        }
    }
}

Проверка чисел

Вторая задача включает проверку чисел. Цель состоит в том, чтобы определить, представляет ли данная строка допустимое число. Критерии допустимого номера:

  1. Целое число, за которым может следовать экспоненциальная запись.
  2. Десятичное число, за которым может следовать экспоненциальная запись.
  3. Целое число может опционально иметь знак (- или ), за которым следуют цифры.

Примеры

  • Ввод: «1» → Выход: true
  • Ввод: «a» → Выход: false
  • Вход: "." → Вывод: ложь
  • Ввод: «1.2e4.2» → Выход: false
  • Ввод: «-1». → Выход: правда
  • Ввод: «1E-8» → Выход: true
  • Ввод: «.44» → Выход: true

Решение

Perl-реализация

#!/usr/bin/perl
use strict;
use warnings;

sub is_valid_number {
    my ($str) = @_;

    # Regex for valid numbers
    my $regex = qr{
        ^            # Start of the string
        [ -]?        # Optional sign
        (?:          # Start of the number group
            \d       # Integer: at least one digit
            (?:      # Start of the optional decimal part
                \.   # Decimal point
                \d*  # Followed by zero or more digits
            )?       # Group is optional
            |        # or
            \.       # Just a decimal point
            \d       # Followed by one or more digits
        )            # End of the number group
        (?:          # Start of the optional exponent group
            [eE]     # 'e' or 'E'
            [ -]?    # Optional sign
            \d       # Followed by one or more digits
        )?           # Exponent is optional
        $            # End of the string
    }x;

    # Return 1 for valid, 0 for invalid
    return $str =~ $regex ? 1 : 0;
}

1;

Тесты реализации Perl

#!/usr/bin/perl
use strict;
use warnings;
use Test::More;

require './ch-2.pl';

# Define test cases
my @test_cases = (
    ["1", 1, 'Valid integer'],
    ["a", 0, 'Invalid input'],
    [".", 0, 'Single dot'],
    ["1.2e4.2", 0, 'Invalid exponent'],
    ["-1.", 1, 'Valid decimal'],
    [" 1E-8", 1, 'Valid scientific notation'],
    [".44", 1, 'Valid decimal starting with dot'],
);

# Loop through test cases and run tests
foreach my $case (@test_cases) {
    my $result = is_valid_number($case->[0]);
    is($result, $case->[1], $case->[2]);
}

done_testing();

Перейти к реализации

package main

import (
    "regexp"
)

// isValidNumber checks if the given string is a valid number.
func isValidNumber(str string) bool {
    regex := `^[ -]?((\d (\.\d*)?)|(\.\d ))([eE][ -]?\d )?$`
    matched, _ := regexp.MatchString(regex, str)
    return matched
}

Тесты реализации Go

package main

import (
    "testing"
)

func TestIsValidNumber(t *testing.T) {
    testCases := []struct {
        input    string
        expected bool
    }{
        {"1", true},
        {"a", false},
        {".", false},
        {"1.2e4.2", false},
        {"-1.", true},
        {" 1E-8", true},
        {".44", true},
    }

    for _, tc := range testCases {
        result := isValidNumber(tc.input)
        if result != tc.expected {
            t.Errorf("isValidNumber(%q) = %v; expected %v", tc.input, result, tc.expected)
        }
    }
}

Заключение

Эти решения предоставляют эффективные методы оценки надежности пароля и проверки правильности чисел. Полный код обеих задач доступен на GitHub.

Заявление о выпуске Эта статья воспроизведена по адресу: https://dev.to/aplgr/exploring-password-strength-and-number-validation-in-perl-and-go-529p?1 Если есть какие-либо нарушения, свяжитесь с Study_golang@163. .com, чтобы удалить его
Последний учебник Более>

Изучайте китайский

Отказ от ответственности: Все предоставленные ресурсы частично взяты из Интернета. В случае нарушения ваших авторских прав или других прав и интересов, пожалуйста, объясните подробные причины и предоставьте доказательства авторских прав или прав и интересов, а затем отправьте их по электронной почте: [email protected]. Мы сделаем это за вас как можно скорее.

Copyright© 2022 湘ICP备2022001581号-3