0

首先,对不起,代码有点乱。它的格式不太好。我的任务是随机生成一个由大小写字母组成的密码,长度由用户指定。到目前为止,我的代码还没有完成,但那是因为我遇到了问题。

我的密码会显示小写和大写字母,但不够长。

例如,如果这个人想要一个长度为 14 的密码,我只会得到一个小于该长度的密码。它永远不是它应该的长度。

import java.util.Scanner;
import java.util.Random;

public class Password{
    public static void main(String [] args){
        Scanner in = new Scanner(System.in);
        int passwordLength = 0;
        Random randNum = new Random();
        int randNumAscii = 0;
        String generatedPassword = "";

        System.out.print("Password Length (1-14): ");
        passwordLength = in.nextInt();
        for(int count = 0; count < passwordLength; count++){ 
            randNumAscii = randNum.nextInt(123);
            if(randNumAscii >= 65 && randNumAscii <= 90 || randNumAscii >= 97 && randNumAscii <= 122)
                generatedPassword += (char)randNumAscii;
            else
                randNumAscii = randNum.nextInt(123); 
        }
        System.out.println(generatedPassword);
    }
}
4

2 回答 2

1

这是因为您只在生成的密码中添加一个字符(如果它在您选择的范围内)。如果一个字符在您之外随机化,则randNumAscii >= 65 && randNumAscii <= 90 || randNumAscii >= 97 && randNumAscii <= 122永远不要将其附加到字符串中。

您可以做的是在 for 循环内有一个 while 循环,该循环一直持续到满足该条件,或者继续 for 循环但将 count 变量减一,因此可以说“使用该索引”生成一个新字符。

于 2012-10-14T00:46:32.057 回答
1

如您所说,您的问题出在此处:

randNumAscii = randNum.nextInt(123);
if(randNumAscii >= 65 && randNumAscii <= 90 || randNumAscii >= 97 && randNumAscii <= 122)
    generatedPassword += (char)randNumAscii;
else
    randNumAscii = randNum.nextInt(123); 

让我解释一下原因:

基本上,当 时userSelection == 2,您的代码说:“对于给定长度的每个空格,选择一些随机字符。如果它是大写或小写,则添加它。否则,更改它。” 但是,您忘记做的是附加“更改”的随机字符。

你需要在这里做的是这样的(伪代码):

randNumAscii = [random from 0 to 123]
while randNumAscii is not uppercase and not lowercase:
    randNumAscii = [random from 0 to 123]
append (char)randNumAscii to generatedPassword

由于这是一项任务,因此我将实施留给您。因为我不确定您的技能水平,您可能需要阅读while.

于 2012-10-14T00:47:00.620 回答