Ich habe mir hier ziemlich viel den Kopf gekratzt und konnte keine Lösung finden. Ich habe diesen Code geschrieben, um einfache 4 Zeichen Passwörter zu knacken (siehe Code unten). Ich kann sehen, dass die Passwörter korrekt generiert werden und dass jede Möglichkeit mit jeder Kombination von Buchstaben von A bis Z getestet wird, aber die Schleife endet nie. Kann mir jemand sagen warum?Krypta Brute Force nie endende Schleife
#include <cs50.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <crypt.h>
int main(int argc, string argv[])
{
//check number of arguments
if(argc != 2)
{
printf("Usage: ./crack hash\n");
}
char str[5];
char salt[] = "..";
strncpy(salt, argv[1], 2);
string hash = argv[1];
string password = "....";
char pass[5];
//brute force loop
for(int i = 65; i < 123; i++)
{
str[0] = i;
for(int j = 65; j < 123; j++)
{
str[1] = j;
for(int k = 65; k < 123; k++)
{
str[2] = k;
for(int l = 65; l < 123; l++)
{
str[3] = l;
str[4] = '\0';
strcpy(pass, str);
password = crypt(pass, salt);
if (hash == password)
{
printf("%s\n", password);
break;
}
printf("\r%s", pass);
fflush(stdout);
}
}
}
}
}
Sie brechen nur die vierte Schleife. Die anderen setzen fort –
Es sollte immer noch nach dem Ausprobieren aller Kombinationen enden und nicht endlos sein. Vielleicht ist die Frage schlecht formuliert. – AlastairG
Was ist der "String" -Typ? – AlastairG