Brute force script in Python 3.2

69,801

Solution 1

Code first:

from itertools import product

chars = '0123456789' # chars to look for

for length in range(1, 3): # only do lengths of 1 + 2
    to_attempt = product(chars, repeat=length)
    for attempt in to_attempt:
        print(''.join(attempt))

itertools.product produces a Cartesian join of its input(s) - in this case, it's being 'joined' to itself. So in the first iteration, each single character is printed. Then in the next iteration, because of repeat=length (and length is now == 2), generates '00', '01', etc... It's worth trying it and seeing the output to understand it better.

This also means you can throw in letters (uppercase/lowercase), and change the upperbound in the range function.

It's certainly not going to break the world of code-breaking, but should give you an idea of the flexibility of Python and the tools available to you.

I'll leave you to check the passwords match and break out the loop.

Solution 2

You want something like this:

PassWord = str(random.randint(0,9999))#example password 
for i in range(10000):    #0-9999
   Trial = str(i)  
   if Trial == Password:  
       print('Found password: ' + Password) 

Solution 3

just run this programme and you will get what you want. but remember to change the values of fields where I've commented in code.

import random
import time
import os
from tqdm import tqdm
import random
import getpass

def loading():
    for index in tqdm(range(100), desc = "loading..."):
        time.sleep(0.1)

    pss = random.randint(1, 9)
    print("found a digit-", pss)
    print("hunt will continue in 2 seconds...")

def pas():
    pas = getpass.getpass("enter password: ")
    if pas == ("root"):  #you can change it according to your need
        menu()
    else:
        end()

def login():
    usid = input("enter username: ")
    if usid == ("root"): #change this too according to your need
        pas()
    else:
        end()

def end():
    os.system('cls')
    print("okk!! bye...")
    exit()


def menu():
    os.system('cls')
    input("enter ip address:")
    os.system('cls')
    print("starting the hunt...")
    time.sleep(2)
    os.system('cls')

    loading()
    time.sleep(2)
    loading()
    time.sleep(2)
    loading()
    time.sleep(2)
    loading()
    time.sleep(2)
    loading()
    time.sleep(2)
    loading()
    time.sleep(2)
    loading()
    time.sleep(2)
    loading()
    time.sleep(2)
    loading()
    print("completed! combine the digits and that's your password...")
    end()

login()
Share:
69,801
Yeg
Author by

Yeg

Student at the TU Delft

Updated on July 09, 2022

Comments

  • Yeg
    Yeg almost 2 years

    I'm a beginner in writing code and I've started with Python because it seemed the neatest and the easiest to start with (I currently have Python 3.2). Now I've read some online books and so on about coding in python, I've made some small programs and that's it.

    But then I wanted to make a program that could brute-force a random password like:

    PassWord = random.randint(0,9999)
    

    I made something that could try random passwords:

    import random
    PassWord = str(random.randint(0,9999))
    Trial = ' '
    while Trial != PassWord:
        Trial = str(random.randint(0,9999))
        print(Trial)
        if Trial == PassWord:
            print('The password is: '+PassWord)
            input()
    

    But that's not really a brute-force attack, it's more trying to randomly guess a password. I think a Brute-Force attack is first tries all possibility's with 1 digit then 2, 3 and so on. But I have no clue and knowledge how to do this.

    I would really appreciate if someone would say how to create a program that first checks all possibilities with 1 digit and if possible, in the right order (0,1,2,3 and so on), then 2,3 and 4 digits.

    Then I could work around on it, and learn more about Python.