Hashcat 生成密码字典

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hashcat 生成密码字典相关的知识,希望对你有一定的参考价值。

参考技术A 目的:

猜测密码组成习惯:

分析:

生成字典:

清洗数据:

破解:

管理员出于方便记忆只是将生日改动了一下,老毛病了

C语言实现密码字典生成器

使用C语言实现一个简单的密码字典生成器

介绍

在密码长度固定时,用简单的多重循环很容易就实现密码字典的生成,但是当密码长度较长或者密码长度不固定时,这种多重循环很难完成我们的需求了,遇到这样的问题,应该就需要交给递归了,这篇文章所描述的密码字典生成器就是利用递归算法来实现的。后来又增加了生日密码模式的功能,虽然这个功能很简陋,但也使其功能得以拓展。

递归生成字典函数

定义了全局变量来记录字典空间,利用递归算法实现了密码字典的生成。

#include<stdio.h>

int n=0,l,flag=0;
int min,max; 
char p[10];

print(int n,int l,FILE* pf)

	int j;
	if(n==l)
	
		fprintf(pf,"%s\\n",p);
		flag++;
		return;
	
	for(j=min;j<=max;j++)
	
		p[n]=(char)j;
		print(n+1,l,pf);
	

生日字典函数

简单的闰年判断和月份日期遍历。

printday(int ymin,int ymax,FILE* pf)

	int y,m,d,dmax;
	for(y=ymin;y<=ymax;y++)
	
		for(m=1;m <= 12;m++)
		
			if(m==4||m==6||m==9||m==11)
				dmax=30;
			else if(m==2 && ((y%4==0&&y%100!=0)||y%400==0)==1)
				dmax=29;
			else if(m==2 && ((y%4==0&&y%100!=0)||y%400==0)==0)
				dmax=28;
			else
				dmax=31;
			for(d=1;d<=dmax;d++)
			
				fprintf(pf,"%04d%02d%02d\\n",y,m,d);
				flag++;
			
		
	

主函数

这一部分主要实现了功能的选择以及对一些参数的初始化设置。

int main()

	int s1,s2;
	int ymin,ymax; 
	FILE* pf = fopen("dict.txt", "w");
	printf("请选择字典模式:\\n");
	printf("1:字符串字典 2:生日字典\\n");
	scanf("%d",&s1);
	if(s1==1)
	
		printf("请输入字符串长度:\\n");
		scanf("%d",&l);
		printf("请选择基础字符:\\n");
		printf("1:大写字母 2:小写字母 3:数字\\n");
		scanf("%d",&s2);
		if(s2==1)
			min=65, max=90;
		else if(s2==2)
			min=97, max=122;
		else
			min=48, max=57;
		printf("正在执行,请稍候...\\n");
		print(n,l,pf);
	
	else
	
		printf("请输入初始年份:\\n");
		scanf("%d",&ymin);
		printf("请输入终止年份:\\n");
		scanf("%d",&ymax);
		printf("正在执行,请稍候...\\n");
		printday(ymin,ymax,pf);
	 
	printf("执行成功,字典空间为%d",flag);
	return 0;

运行样例展示




以上是关于Hashcat 生成密码字典的主要内容,如果未能解决你的问题,请参考以下文章

什么工具能将给定的几个单词的所有组合生成指定位数的字典?跑hashcat用

ewsa hashcat哪个跑包快

hashcat使用教程

有五个压缩包,密码一样但是不知道,如何在不知道密码不损坏文件基础上用啥软件具体操作过程可追加?

C语言实现密码字典生成器

C语言实现密码字典生成器