Как избежать полной ошибки памяти в JavaScript - PullRequest
0 голосов
/ 20 октября 2018

Я пытаюсь написать базовый скрипт типа bruteforce для работы на примерной странице php, которую я создал.Вот сценарий, который я написал:

var userElement = document.getElementById('username');
var passElement = document.getElementById('password');
//sets username, not randomized
var username = 'admin';
//expected characters
var alphabet = ['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', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '!', '@', '#', '$', '%', '^', '&', '*', '(', ')'];
var numOfGuesses = 0; //for fun
var numOfGuessesGenerated = 0; //for fun
var guesses1 = [];
var guesses2 = [];
var guesses3 = [];
var guesses4 = [];
var guesses5 = [];
var guesses6 = [];
var guesses7 = [];
var guesses8 = [];
var guess = "";
var memhandle = 0;

//first for loop is to get all different lengths covered, max being sixteen
var maxNumOfChars = 16;
//generates guesses one character at a time and appends them to array name guesses
for (var y = 0; y < maxNumOfChars; y++) {
    for (var i = 0; i < alphabet.length; i++) {
    while (i < maxNumOfChars) {
            guess+=alphabet[i];
    }
    }
    if (memhandle == 0) {
        guesses1.push(guess);
        memhandle = 1
    } else if (memhandle == 1) {
        guesses2.push(guess);
        memhandle = 2;
    } else if (memhandle == 2) {
        guesses3.push(guess);
        memhandle = 3;
    } else if (memhandle == 3) {
        guesses4.push(guess);
        memhandle = 4;
    } else if (memhandle == 4) {
        guesses5.push(guess);
        memhandle = 5;
    } else if (memhandle == 5) {
        guesses6.push(guess);
        memhandle = 6;
    } else if (memhandle == 6) {
        guesses7.push(guess);
        memhandle = 7;
    } else if (memhandle == 7) {
        guesses8.push(guess);
        memhandle = 0;
    } 


    numOfGuessesesGenerated++;
    guess = "";
}

numOfGuessesesGenerated++;
console.log(numOfGuessesesGenerated);
console.log(guesses);

//try the guesses!
for (var x = 0; x < guesses.length; x++) {
    userElement.value = username;
    passElement.value = guesses[x];
    numOfGuesses++;
    console.log(numOfGuesses);
    document.getElementById("myForm").submit(); //myForm IS the name of the form
}   



document.getElementById("fid").submit();  

Причина, по которой я включил переменную "memhandle", заключалась в том, чтобы попытаться разделить все догадки на разные массивы, и поэтому у меня так много массивов.Страница постоянно вылетает всякий раз, когда я пытаюсь это сделать, есть ли способ, которым я могу сделать это только с помощью javascript, или мне нужно где-то хранить имена пользователей, а затем извлекать их оттуда?Я внедряю javascript, просто делая javascript: в строке URL, и это также может быть причиной моих проблем.Любая помощь приветствуется

1 Ответ

0 голосов
/ 20 октября 2018

Основная проблема у вас while (i < maxNumOfChars) {.Этот цикл никогда не завершится.Вы делаете guess+=alphabet[i];, но вы вообще не увеличиваете i (внутри этого цикла), так что в конечном итоге это приводит к сбою.

Могу ли я порекомендовать посмотреть на функции итератора , чтобы избежатьмассив вообще?

var userElement = document.getElementById('username');
var passElement = document.getElementById('password');
//sets username, not randomized
var username = 'admin';
//expected characters
var alphabet = ['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', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '!', '@', '#', '$', '%', '^', '&', '*', '(', ')'];
var numOfGuesses = 0; //for fun
var numOfGuessesGenerated = 0; //for fun
var guess = "";
var memhandle = 0;

//first for loop is to get all different lengths covered, max being sixteen
var maxNumOfChars = 16;
//generates guesses one character at a time and appends them to array name guesses
function *getNextGuess() {
  for (var y = 0; y < maxNumOfChars; y++) {
      for (var i = 0; i < alphabet.length; i++) {
        //while (i < maxNumOfChars) {
              guess+=alphabet[i];
        //}
      }
      yield guess;
  }
}

//try the guesses!
for (var guess of getNextGuess()) {
  console.log(guess);
  numOfGuesses++;
  console.log(numOfGuesses);
  
  if (numOfGuesses > 10)
    break;
}   



//document.getElementById("fid").submit();  
...