Tutorial: Create Wordlists with Crunch

Create Wordlists with Crunch

Greetings all. Before I get into the tutorial, I would like to mention that I am fairly new to Null Byte (been lurking for some time though), and what really appeals to me about this place is its tight, family-like community where everyone is always willing to help each other and the constant search for knowledge that inhabits this subdomain is a driving motivator for me to join in. I'm glad I arrived at the right time. Anyway, wipes tears (not really)...

This is a tutorial for newbies and anyone who hasn't yet used Crunch before. Crunch is a utility that is used to create wordlists using letters, numbers, and symbols for every possible combination or according to specific rules. I will be covering this command-line tool in great depth, dissecting each option and demonstrating its purpose. So to start off, in this demonstration I will not assume that you have a particular OS, other than to mention that I will only be covering those based on UNIX.

To begin with, download Crunch and navigate to the downloaded tgz file in Terminal. Then unzip the tgz file and install crunch.

> cd /path/to/folder/containing/crunch-3.6.tgz
> tar -xf crunch-3.6.tgz
> cd crunch-3.6 && make && make install

So now you can call the crunch command from anywhere in the Terminal app. Great, so now that it's out of the way, let's get straight into the usage. The syntax for Crunch is:

> crunch min max charset options

The min and max are the minimum and maximum lengths (respectively) for your desired wordlist. By default charset is not required, but you can use it to limit the characters of your wordlist to the ones you specify. If you choose to use charset then you must maintain the correct order, which is lowUP123@%# (lowercase letters, then uppercase letters, then numbers and finally symbols). You can skip any of them, but the order must always remain the same. Example:

> crunch 2 6 qrs347

The command above will produce a wordlist for every possible combination of the characters qrs347 from 2 to 6 characters in length.

Now let's look at the options.

-b : the maximum size of the wordlist (requires -o START)
-c : numbers of lines to write to the wordlist (requires -o START)
-d : limit the number of duplicate characters
-e : stop generating words at a certain string
-f : specify a list of character sets from the charset.lst file
-i : invert the order of characters in the wordlist
-l : allows the literal interpretation of @,%^ when using -t
-o : the output wordlist file
-p : print permutations without repeating characters (cannot be used with -s)
-q : Like the -p option except it reads the strings from a specified file
-r : resume a previous session (cannot be used with -s)
-s : specify a particular string to begin the wordlist with
-t : set a specific pattern of @,%^
-z : compress the output wordlist file, accompanied by -o

Reference:
@ represents lowercase letters
, represents uppercase letters
% represents numbers
^ represents special characters

Examples:

1) > crunch 5 5 abcde14 -t @@@14 -d 2@ -o syskey.txt -z

A zipped syskey.txt wordlist starting with "aab14" and ending in "eed14" will be produced from the above. The reason why the start is not "aaa14" is because -d 2@ allows for only 2 duplicate lowercase letters. Adding -i would invert the results, and adding -e dde14 would stop after the line "dde14" (or "41edd" in the case of an inverted output) is produced.

2) > crunch 5 5 bcopuw2468 -s cow28 -c 33 -b 20mb -o START

The above will result in a 20mb text file and containing combinations for bcopuw2468 starting with "cow28" and ending on the 33rd line of the theoretical outcome.

3) > crunch 2 4 -p kite sky car -o owl.txt

In this example the words 'kite' 'sky' and 'car' will be printed in all orders possible (wholly, not by letter) and outputted into output owl.txt without taking into account the min and max numbers. None of the words will be repeated. If only one word is included, it will will be used as a character set. You could use -q instead of -p to extract words from a specific file.

4) > crunch 6 6 -t @^42%3 -l a^aaaa -o art.txt

In this case Crunch will will treat the ^ symbol as itself, rather than a representative of a special character. The sequence will commence with "a^4213" and end in "z^4293" and the output art.txt will be produced.

5) > crunch 4 6 -f /path/to/charset.lst -o words.txt

Assume the situation where you enter the above command and then decide to pause the process midway. When you come back later, you may restore the session by adding -r option to the syntax, while keeping the rest exactly the same.

If you still feel the need to mud your feet by reading paragraphs of illustrations and explanations for eons, you may type...

> man crunch
...to view the Crunch manual, but there's no need since we've just examined it from head to toe.

Now that we have it all covered, you have access to limitless ways in which you could use Crunch during a penetration test. One could obviously point out that it acts great as a password generator, so in turn being useful for password cracking using let's say Hydra or John. I will divulge all of the uses of wordlists in a future tutorial, and other utilities that you could use to perfect the relevance of the contents of said wordlists, thereby enabling a more thorough approach to password cracking or other similar scenarios.

Before concluding this how-to, I would like to mention that I will be prolonging this series to cover many different tools used in the sphere of hacking, and possibly a future series relating to privacy and how it can be achieved in an effective way. Please feel free to add suggestions to anything. I'm more than happy to receive feedback.

That's it for today, I hope you all learned the ins and outs of the tool Crunch, and expect many similar tutorials in the coming days/weeks.

TRT

Just updated your iPhone? You'll find new emoji, enhanced security, podcast transcripts, Apple Cash virtual numbers, and other useful features. There are even new additions hidden within Safari. Find out what's new and changed on your iPhone with the iOS 17.4 update.

14 Comments

nice start and welcome to null byte

hacked by Mr_Nakup3nda

Much appreciated :)

There is an article here on Null Byte about using Crunch to make wordlists, but this is a nice companion piece. :)

Yes, I am aware of that. Though my approach was more on how to use the tool and covering all of its options, rather than the basics and its purpose. Nevertheless, thank you for mentioning this :)

Very good tutorial. Welcome to Null Byte, TRT!

Thank you for the warm welcome :)

I need something like crunch but for windows. Can you name a few if you know of any?

Hello,

I know that my password have a minimum of 1 letter and 1 number. how can i exclude that kind of word: 128458436 or jfndcystf. My password looks like this : 15cd5ddd563

HI,i hope someone could help me,How can i do or can it be done with crunch?a wordlist with this pattern:

xyxyxy where x=aeiou and y=bcdf and then yxyxyx then,yxxyxy,, but never 3 x or 3y in a row. All Permutations never 3 same charathers in a row andwith my own characters dictionary..i only need 2 dictionaries:1=aeiou and 2=bcdfgh

so im trying to create a wordlist of 8 numers but in this wordlist im trying to set all the first 3 numbers to be "014" right?? plsss help

so i follow the instructions and go: crunch 8 8 1234567890 -s 014

what am i doing wrong? i get this :
fillpatterninfo: Internal error: Can't find char at pos #1 in cset

Hey guys. I've been trying to read as much material and watch as many videos as my life will allow before asking such a specific question as the one I have for you.

I am surrounded by ATT networks. My parents have had multiple ATT routers.

I've taken the list I have made of every default pw. and so far they all fit some rules. Im sure I need alot more data, but i still think its worth a try as I gather more info

I am just now getting back into the world of computers after 14 years off.(long vacation)
Maybe someone can help guide me in another direction?(I am waiting on wifi adapter necessary for karma, mitm, etc)
I THINK I want ........to create a wordlist that will be.
-10 characters long. not 1-9
-have 0-4 digits ranging from 0-9
-no repeating digits
-maximum times a character can be used 3
-no pair of repeating characters (like no ssrr)
-maximum allowed repeating for characters of same capitilization is . rr RR no RRRrrr. rRr is ok.

anyway. Maybe I should have just said, "Hey guys, can you help direct me to more guides and tutorials concerning wordlists and generating wordlists with specific rules? "Maybe even just a short response on ways you manipulate the syntax and stuff. Or advice on what helped you learn will be appreciated.

I almost posted on a random topic just to ask for help with the forum to be honest. I go to /forum/ and I looked as well as my wife and we feel like tards because we can't find where to start a new thread or search.

Ok so I'm trying to get the syntax right and need some assistance please and thank you. I'm trying to make a crunch list using min and max as 10(i got that part down) the character-set as 0-9 + Upper and Lower aABbCcDdEeFf(pretty positive I have got this part down as well) BUT here's where I'm trying to downsize the file size because this by itself is WAY too big I need to add the -d option so it doesn't use duplicates but is there a way to make it so that in the entire line each number or letter are used only twice? I have used the -d option but it only stops duplicates from being next to each other and still allows a duplicate further in the line. Ex: I want to generate this...

2f7a3c6b0d

but have it not use any letter or number more than twice at all so

2f7a3c6b2d

would be fine as the number 2 is used only twice

But not like this

2f7a2c6b2d

where the number 2 is used three times.

However I don't want any of the 0-9 or Aa-Ff to be used more than twice. Ugh sorry for the headache lol. Any help with the syntax for crunch with my Kali Linux would be a huge help thanks or if someone has a link to DL this pre-generated list would be awesome.

Much like a Mac address but with only 2 maximum duplicates of each character used in each line with NO need for the #/letter/#/letter pattern at all.

..................................................

Share Your Thoughts

  • Hot
  • Latest