0

我正在尝试构建一个脚本,我需要在其中创建一个具有以下参数的密码生成器:

  • 长度必须至少为 8 个字符,但不得超过 16 个字符。
  • 必须至少包含 1 个数字 (0-9)。
  • 必须至少包含 1 个小写字母。
  • 必须至少包含 1 个大写字母。
  • 必须恰好包含一个且仅一个@ # $ % & * + - =

我有两个想法:

首先 :

#!/bin/bash
#
#Password Generator 
#
#

Upper=('A''B''C''D''E''F''G''H''I''J'K''L''M''N''O''P''Q''R''S''T''U''V''W''X''Y''Z')
Lower=('a''b''c''d''e''z''f''g''h''i''j''k''l''m''o'''p''q''r''s''t''u''v''w''x''y''z')
Numbers=('1''2''3''4''5''6''7''8''9')
SpecialChar=('@''#''$''%''&''*''+''-''=')



if [ S# -eq 0 ] ; then 


Pwlength=`shuf -i 8-16 -n 1` 

Password=`< /dev/urandom tr -dc A-Za-z0-9$SpecialChar | head -c $Pwlength` 

echo "Random Password is being generated for you"

sleep 5

echo "Your new password  is : $Password"


exit

问题是我得到了我什至没有定义的字符?

第二个想法:

for((i=0;i<4;i++)) 

do

password=${Upper[$random % ${#Lower[@]} ] }
password=${Upper[$random % ${#Upper[@]} ] }
password=${Upper[$random % ${#Number[@]} ] }
password=${Upper[$random % ${#SpecialChar[@]} ] }

done

由于某种原因,它们都不起作用;/

4

3 回答 3

0
  • 如前所述,直接使用字符串来处理字符列表会更干净、更容易。处理数组中的特殊字符可能会导致副作用(例如获取当前目录中带有 '*' 字符的文件列表)。此外,数组可能难以作为函数参数传递)。

    ALPHA_LOW="abcdefghijklmnopqrstuvwxyz"
    
    # Then simply access the char in the string at the ith position
    CHAR=${ALPHA_LOW:$i:1}
    
  • 您可以从小写字母生成大写字母。

    ALPHA_UP="`echo \"$ALPHA_LOW\" | tr '[:lower:]' '[:upper:]'`"
    
  • 包含随机数的变量是$RANDOM(大写字母)。

  • sleep 5是不必要的。

  • 您需要找到一种方法来计算每种字符类型的剩余出现次数。有关更多信息,我编写了一个完整的脚本来执行您在此处描述的操作。

于 2016-04-11T06:04:18.680 回答
0

您的第一次尝试有以下问题:

  • 您正在使用数组来包含单个字符串。粘贴'A''B''C'相当于'ABC'. 简单地将这些转换为标量变量可能是最简单的解决方法。
  • 你没有引用你的变量
  • 您声明Upper,LowerNumbers, 但从不使用它们。
  • 无论如何,将变量用于您只使用一次(或更少:-)的东西是可疑的。
  • 正如@KevinO 所指出的,破折号在 中具有特殊含义tr,如果您想从字面上匹配它,则需要在第一个或最后一个。

最重要的是,sleep 5它似乎没有任何有用的目的,如果它还没有,它会开始惹恼你。如果您真的想要一台速度较慢的计算机,我敢肯定这里有人愿意交易。

您的第二次尝试有以下问题:

  • Bash 中的特殊变量$RANDOM全部大写。
  • 您正在尝试对未明确定义的字符数组(未加引号!)进行模运算。之后的除数%必须是单个整数。您可以将字符代码转换为整数,但这有点痛苦,而且您还不清楚您希望得到什么结果。

快速尝试修复第一次尝试将是

Password=$(< /dev/urandom tr -dc 'A-Za-z0-9@#$%&*+=-' | head -c $(shuf -i 8-16 -n 1))

如果您想验证生成密码的某些属性,我仍然不明白您为什么需要数组。

while read -r category expression; do
    case $Password in
      *[$expression]*) continue;;
      *) echo "No $category"; break;;
    esac
done <<'____HERE'
    lowercase a-z
    uppercase A-Z
    numbers   0-9
    specials  -@#$%&*+=
HERE
于 2016-04-08T09:41:22.633 回答
0

在您的第一个示例中,将“-”字符移动到 SpecialChar 的末尾。我认为您的定义导致允许“+”到“=”(即,传递给 tr 的值读取为“+-=”),这说明了您不期望的字符。或者,将“-”替换为“_”。

So, try a definition like:
SpecialChar=('@''#''$''%''&''*''+''=''-')
于 2016-04-08T05:39:44.870 回答