Crunch在肾透测试和各种暴力测试中,我们需要各种各样的密码字典。github上面的字典五花八门,但是没有一款适合自己。那么,如何制作自己的字典文件呢?Crunch是C语言开发的一种工具,可以创建自定义可修改的单词列表。在本文中,我们将详细讲解Crunch的使用。

安装

Crunch默认安装在Kali Linux上,如果其他系统也可以用apt命令安装。

apt-get install crunch

运行crunch生成字典,要求我们输入要生成的单词的最小最大值以及输出文件,它会自动将小写字母表作为字符集并生成字典。

Crunch从入门到精髓_随机数

示例1

生成最短1个长度,最长为3个长度。

crunch 1 3 -o kali.txt

Crunch从入门到精髓_随机数_02

Crunch从入门到精髓_随机数_03

自定义字母和数字字符

当然,我们可以做字母和数字两者的结合。如下:

crunch 5 7 pass123 -o kali.txt

代码说明:以p a s s 1 2 3这七个字母和数字进行排列组合,生成最短5位,最长7位的字典。

Crunch从入门到精髓_bc_04

创建带有符号的字典

@ :将插入小写字符

:将插入大写字符

% :将插入数字

^ :将插入符号

固定单词 + 3 个数字

假设我们要将前3个字母固定为bbs,并在每个单词6个字符,最后3个位置插入随机数字组合,则可以通过指定模式来完成。

crunch 6 6 -t bbs%%% -o num.txt

Crunch从入门到精髓_bc_05

固定单词 + 3 个大写字母

假设我们要将前3个字母固定为bbs,并在每个单词6个字符,最后3个位置插入大写字母的随机组合,则可以通过以下方式完成

crunch 6 6 -t bbs,,, -o kali.txt

Crunch从入门到精髓_bc_06

固定单词 + 3 个小写字母
crunch 6 6 -t bbs@@@ -o kali.txt
固定单词 + 3 个符号
crunch 6 6 -t bbs^^^ -o kali.txt
小写字母(a,b 或 c)+ 数字 (1,2 或 3) + 符号 (ANY)

在下面的示例中,使用了abc 123。还使用+运算符。我们要创建一个字典,其中第一个字符小写数字作为第二个字符,符号作为第三个字符,但只有abc作为字符,123分别作为数字和最后一个位置上的任何随机符号,命令如下:

crunch 3 3 abc + 123 -t @%^ -o kali.txt

Crunch从入门到精髓_bc_07

两个数字(1、2 或 3)+ 小写字母 (ANY) + 符号 (ANY)

类似地,要创建一个 2 位数字的每个单词 4 个字符的模式(仅包含 1,2 或 3)+ 小写的字母 + 符号,我们可以这样做:

crunch 4 4 + + 123 + -t %%@^ -o kali.txt

这时+ +起到了两个占位符

Crunch从入门到精髓_随机数_08

压缩单词列表

通常,单词列表在文本格式中太大,gzip可用于将其压缩到60-70%以上。

crunch 4 7 Pass123 -z gzip -o START