背景:

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第1张原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第2张

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第3张

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第4张

首先我们需要一点点python基础,比如可以运行类似下面的代码

import requests

headers={
    "xxx":"xxx",
    "xxx":"xxx",
}
url="https://www.ooo.ooo"
r=requests.get(url,headers=headers)
原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第5张 原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第6张

开始!!!

先打开app搜索

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第7张

找到对应的接口,分析一下请求参数,这个工具叫http Debugger Pro

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第8张

有一个sig参数对链接做了签名,看起来像md5

我们需要生成sig参数来伪造请求

反编译apk,搜索"sig"

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第9张

显然是v3.sig,点点点。。。

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第10张

在generatorSigWithFinal生成这个sig

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第11张

点进去发现这是一个native方法,写在release_sig里

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第12张

如果想知道这个方法怎么用,可以用frida hook generatorSigWithFinal看看参数是什么

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第13张

很明显,arg0是路径,arg1是链接参数值,arg2是固定字符串,arg3是上下文

解压apk的librelease_sig.so看看nativeGeneratorSig

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第14张

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第15张

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第16张

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第17张

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第18张

果然是md5,在update和return 打断点 看看参数和结果是什么

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第19张

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第20张

update:

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第21张原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第22张

显然参数是arg0+arg1+固定字符串+时间戳+固定字符串,其中arg1做了升序排序

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第23张

复制出来字符串然后md5,对比就是这个~

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第24张

之后又对md5结果做了处理,交换奇数位和偶数位的位置

生成sig参数:

1.取出链接里的路径和参数的值

2.参数值按升序排序拼接成的字符串

3.拼接加密字符串:路径+参数字符串+bdaefd747c7d594f+时间戳+Tw5AY783H@EU3#XC

4.对加密字符串md5,交换奇数位和偶数位的位值

python版本实现:

def gen_sig(url, sigtime):
    url = parse.unquote(url)
    v1 = [i.split("=")[1] for i in url.split("&") if "sig" not in i]
    v1.sort()
    v0 = url.split("?")[0].split("com/")[1]
    vr = v0 + "".join(v1).replace("+", " ") + "bdaefd747c7d594f" + str(sigtime) + "Tw5AY783H@EU3#XC"
    sig = encrypt(vr)
    return url + "&sig=" + sig + "&sigVersion=1.3" + "&&sigTime=" + str(sigtime)


def encrypt(v0):
    v1 = hashlib.new('md5', v0.encode()).hexdigest()
    v2 = v1[1::2]
    v3 = v1[::2]
    return "".join(i + j for i, j in zip(v2, v3))

有sig就可以伪造请求

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第25张

提取里面的视频地址:

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第26张

写一个save函数,输入链接下载视频

def save_video(url):
    print("save:"+url)
    r=requests.get(url)
    with open(url.split("?")[0].split("_")[-1],"wb")as f:
        f.write(r.content)
原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第27张

改成:

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第28张原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第29张

 

原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第30张

 原创 | sig算法揭秘---50行代码下载5000万小姐姐自拍小视频 Python 第31张

 

哈哈 全部代码放到github里,欢迎star

https://github.com/heyaug/sign-algorithms

 

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄