当前位置:首页 > 文章列表 > Golang > Go教程 > 在 Perl 和 Go 中探索密码强度和数字验证

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

来源:dev.to 2024-09-24 17:37:01 0浏览 收藏

一分耕耘,一分收获!既然都打开这篇《在 Perl 和 Go 中探索密码强度和数字验证》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎大家积极提出!在后续文章我会继续更新Golang相关的内容,希望对大家都有所帮助!

在 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)
        }
    }
}

验证数字

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

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

理论要掌握,实操不能落!以上关于《在 Perl 和 Go 中探索密码强度和数字验证》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
Golang 测试框架的优劣比较Golang 测试框架的优劣比较
上一篇
Golang 测试框架的优劣比较
升级Win11之后显示Windows许可证即将过期怎么解决
下一篇
升级Win11之后显示Windows许可证即将过期怎么解决
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    514次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    499次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • SEO  AI Mermaid 流程图:自然语言生成,文本驱动可视化创作
    AI Mermaid流程图
    SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
    414次使用
  • 搜获客笔记生成器:小红书医美爆款内容AI创作神器
    搜获客【笔记生成器】
    搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
    400次使用
  • iTerms:一站式法律AI工作台,智能合同审查起草与法律问答专家
    iTerms
    iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
    430次使用
  • TokenPony:AI大模型API聚合平台,一站式接入,高效稳定高性价比
    TokenPony
    TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
    435次使用
  • 迅捷AIPPT:AI智能PPT生成器,高效制作专业演示文稿
    迅捷AIPPT
    迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
    403次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码