0

0

在 Perl 和 Go 中探索密码强度和数字验证

聖光之護

聖光之護

发布时间:2024-09-25 14:28:59

|

768人浏览过

|

来源于dev.to

转载

在 perl 和 go 中探索密码强度和数字验证

在本文中,我将解决 perl weekly challenge #287 中的两个挑战:加强弱密码和验证数字。我将为这两项任务提供解决方案,展示 perl 和 go 中的实现。

目录

  1. 加强弱密码
  2. 验证数字
  3. 结论

加强弱密码

第一个任务是确定使密码更安全所需的最少更改次数。强密码的标准是:

  1. 至少有 6 个字符。
  2. 至少包含 1 个小写字母、1 个大写字母和 1 个数字。
  3. 不包含三个连续相同的字符。

示例

  • 输入:“a”→输出:5
  • 输入:“ab2”→ 输出:3
  • 输入:“paasw0rd”→输出:0
  • 输入:“paaasw0rd”→输出:1
  • 输入:“aaaaa”→输出: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 < 6) ? max(6 - $length, $types_needed) : $types_needed + $repeats;
}

1;

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 < len(password); i++ {
        if password[i] == password[i-1] {
            count++
        } else {
            repeats += count / 3
            count = 1
        }
    }
    repeats += count / 3
    return repeats
}

func minimumstepstostrongpassword(password string) int {
    length := len(password)

    // use regex to check for character types
    haslower := regexp.mustcompile(`[a-z]`).matchstring(password)
    hasupper := regexp.mustcompile(`[a-z]`).matchstring(password)
    hasdigit := regexp.mustcompile(`\d`).matchstring(password)

    // calculate the number of types needed
    typesneeded := booltoint(!haslower) + booltoint(!hasupper) + booltoint(!hasdigit)

    repeats := countrepeats(password)

    // return the minimum steps based on the length of the password
    if length < 6 {
        return max(6-length, typesneeded)
    }
    return typesneeded + repeats
}


func booltoint(b bool) int {
    if b {
        return 1
    }
    return 0
}

func max(a, b int) int {
    if a > 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)
        }
    }
}

验证数字

第二个任务涉及验证数字。目标是确定给定的字符串是否代表有效的数字。有效号码的标准是:

Napkin AI
Napkin AI

Napkin AI 可以将您的文本转换为图表、流程图、信息图、思维导图视觉效果,以便快速有效地分享您的想法。

下载
  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 上提供了这两项任务的完整代码。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

249

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

205

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1435

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

609

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

547

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

539

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

158

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

77

2025.08.07

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.3万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号