刚出炉的Android KeyGenMe
小白第一次发,大家可以练练手本帖最后由 wzp1995 于 2024-7-30 07:26 编辑
我来理一下思路
1.直接搜关键字:注册
2.看到成功之后还有一个判断,成立才显示成功,否则失败
3.直接复制粘贴
4.再往上看,到这里基本可以看出注册码是由getFingrtPrint+日期(其实不是日期)组成,这里app就会有时间限制,
还有一种,就是不需要日期判断,trim长度不长于6位,可以无限制使用
5.跟进来看看
(这里str变量我提供一个固定数值“20251111”,有兴趣可以尝试用代码写出来)
5.再往上看,到了解密环节了,点进去看看
6.这是它的解密代码,我们是要给未加密的字符串进行加密
7.这就是加密代码了
8.这里提供一组 (机器码:812177 注册码:52c1573cfb33af3b9d03d8ea8e2c8d45) 虽然看不懂,但是逻辑是这一块了。 本帖最后由 怜渠客 于 2024-7-26 23:51 编辑
该函数中DESede解密的密钥长度须为24,你软件中恒为16,会一直解密失败
瞎搞搞定了,但不是楼主想要的KeyGenMe
怜渠客 发表于 2024-7-26 23:49
该函数中DESede解密的密钥长度须为24,你软件中恒为16,会一直解密失败
我解密和加密都是用的一个密钥,并没有出现你说的情况 from hashlib import md5
from Crypto.Cipher import DES
from Crypto.Util.Padding import pad
from datetime import date
import re
machine_code = input('请输入机器码:')
while True:
end_date = input('请输入注册码截止日期(如2024-1-1):')
pattern = r'{4}-{0,1}-{0,1}'
ret = re.findall(pattern,end_date)
if ret != []:
break
def get_finger_print(s1,s2):
_md5 = md5()
_md5.update((s1+s2).encode('utf8'))
return _md5.hexdigest()[:6]
def set_date(_date:str):
date_split = _date.split('-')
year = int(date_split)
month = int(date_split)
day = int(date_split)
start_date = date(2019,12,1)
end_date = date(year,month,day)
time = (end_date-start_date)*23
return hex(time.days)
def encrypt(trim,end_date):
salt = 'yao123456'
key = salt[:8]
_3des = DES.new(key.encode('utf8'),DES.MODE_ECB)
padded_data = pad((trim+end_date).encode('utf8'),DES.block_size)
cipher = _3des.encrypt(padded_data)
return cipher.hex()
salt = 'yao123456'
trim = get_finger_print(machine_code,salt)
end_date = set_date(end_date)
print(f'你的注册码是:{encrypt(trim,end_date)}')
你使用desede加密,实际是3des,但是由于密钥的两个8字节是相同的,退化成了des,我不知道为什么java对这个不报错?反正在python里就得改成des才行 WXjzc 发表于 2024-8-2 11:50
from hashlib import md5
from Crypto.Cipher import DES
from Crypto.Util.Pa ...
不好意思,我对python不是很熟,无法解答你的问题,等待有缘人 wzp1995 发表于 2024-8-2 20:13
不好意思,我对python不是很熟,无法解答你的问题,等待有缘人
我贴出来的脚本是可以正常运行的注册机。
其实最主要的就是你使用3des这个加密方式,但是密钥却是由两个相同的8字节组成,这是不对的,只是不知道为什么你那边能正常跑
页:
[1]