南邮CTF(cgctf)Misc MD5

本文介绍了一道CTF竞赛中的MD5密文还原题目,通过枚举未知字符,成功还原了部分缺失的MD5值及对应的明文。使用Python进行编程实现,展示了如何在已知部分MD5值的情况下,通过暴力破解找到正确的明文。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目链接:cgctf

这里有一段丢失的md5密文 e9032???da???08????911513?0???a2 要求你还原出他并且加上nctf{}提交

已知线索 明文为: TASC?O3RJMV?WDJKX?ZM

题目来源:安恒杯

 

给出一段不完整的md5值,和一段不完整的明文值。思路比较简单,明文中有3个未知的值,枚举即可。

26+26+9=61个字母和数字字符,再加上符号字符!@#$%^&*()=_/+-等,枚举次数大约是70^3,最后解出来发现明文是大写字母。

python枚举代码:

#e9032???da???08????911513?0???a2

#TASC?O3RJMV?WDJKX?ZM

import hashlib
c='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789*-+&^%$#@!()'

text = 'TASC?O3RJMV?WDJKX?ZM'
md5 = 'e9032???da???08????911513?0???a2'

# md5 compare
def f(md):
	for i in range(0,len(md5)):
		if md5[i] == '?':
			continue
		elif md5[i] != md[i]:
			return 0
		
	return 1

flag = 0
for i in range(0,len(c)):
	if flag == 1:
		break
	for j in range(0,len(c)):
		if flag == 1:
			break
		for k in range(0, len(c)):
			t = 'TASC' + c[i] + 'O3RJMV' + c[j]+'WDJKX'+c[k]+'ZM'
			hash_md5 = hashlib.md5(t)
			flag = f(hash_md5.hexdigest())
			if flag==1:
				print 'Yes' ,t
				print hashlib.md5(t).hexdigest()
				break

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值