当前位置: 首页 > wzjs >正文

庞各庄网站建设公司西安制作网站

庞各庄网站建设公司,西安制作网站,网上哪里可以注册公司,手机便宜网站建设1.目标 网址&#xff1a;https://y.qq.com/n/ryqq/toplist/26 我们知道了 sign P(n.data)&#xff0c;其中n.data是明文的请求参数 2.webpack生成data加密参数 那么 L(n.data)就是密文的请求参数。返回一个Promise {<pending>}&#xff0c;所以L(n.data) 是一个异步函数…

1.目标

在这里插入图片描述

网址:https://y.qq.com/n/ryqq/toplist/26

在这里插入图片描述
在这里插入图片描述
我们知道了 sign= P(n.data),其中n.data明文的请求参数

2.webpack生成data加密参数

在这里插入图片描述
那么 L(n.data)就是密文的请求参数。返回一个Promise {<pending>},所以L(n.data) 是一个异步函数。

L(n.data).then(result => {console.log('结果是:', result);
}).catch(error => {console.error('发生错误:', error);
});

在这里插入图片描述

window.shark(0).cgiEncrypt(data).then(result => {console.log('结果是:', result);
}).catch(error => {console.error('发生错误:', error);
});

运行之后报错

p[r[++h]] = p[r[++h]].call(p[r[++h]], p[r[++h]]);
TypeError: Cannot read properties of undefined (reading 'call')

在这里插入图片描述

因为请求参数是用了AES-GCM加密,且使用了随机iv

AES-GCM 是一种高级加密标准(AES)与伽罗瓦 / 计数器模式(GCM)结合的加密方式

在这里插入图片描述
在浏览器环境中,window.crypto 对象是 Web Crypto API 的入口,用于实现加密相关的功能。window.crypto.subtleSubtleCrypto 接口的实例,它提供了更底层、更强大的加密功能。
SubtleCrypto 的所有方法均返回 Promise,需通过 then/catchasync/await 处理异步结果(例如密钥生成、加密解密等操作)。

所以我们只需要导入

window = globalThis;;
window.crypto = require('crypto');

在这里插入图片描述
就可以正常生成结果

3.逆向还原data加密参数

密钥就是vTBfEND/dLbvVNq4NbXhzw==
在这里插入图片描述
这样生成的结果长度为448,而网页长度是464,少了16位,而这16位正是iv
在这里插入图片描述

AES-GCM 通常需要将 IV 和密文一起传输,接收方才能正确解密
在这里插入图片描述
这样就没有问题

4.响应数据解密

在这里插入图片描述
返回的数据是二进制
在这里插入图片描述
数据解密是用j.__cgiDecrypt,当然也是AES-GCM解密

JSON.parse(N(可快速定位
在这里插入图片描述
在这里插入图片描述

5.绕过加密验证

在这里插入图片描述

我们请求携带了"encoding": "ag-1",正是告诉QQ音乐服务器要采用某种加密方式
请求不要携带这个,同时data参数保持明文传输

import requests
import jsonheaders = {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36","Accept": "application/octet-stream","accept-language": "zh-CN,zh;q=0.9","cache-control": "no-cache","content-type": "text/plain","origin": "https://y.qq.com","pragma": "no-cache","priority": "u=1, i","referer": "https://y.qq.com/","sec-ch-ua": "\"Chromium\";v=\"136\", \"Google Chrome\";v=\"136\", \"Not.A/Brand\";v=\"99\"","sec-ch-ua-mobile": "?0","sec-ch-ua-platform": "\"Windows\"","sec-fetch-dest": "empty","sec-fetch-mode": "cors","sec-fetch-site": "same-site"
}url = "https://u6.y.qq.com/cgi-bin/musics.fcg"
params = {"sign": "zzc308f0fefeuogbgecps0gpzosg6fnvxujyw0474ee6d"
}
data = {"comm": {"cv": 4747474,"ct": 24,"format": "json","inCharset": "utf-8","outCharset": "utf-8","notice": 0,"platform": "yqq.json","needNewCode": 1,"uin": 0,"g_tk_new_20200303": 5381,"g_tk": 5381},"req_1": {"module": "musicToplist.ToplistInfoServer","method": "GetDetail","param": {"topid": 27,"offset": 0,"num": 20,"period": "2025-05-29"}}
}
data = json.dumps(data, separators=(',', ':'))
response = requests.post(url, headers=headers, params=params, data=data)print(response)
print(response.text)

也就是说只需要分析sign即可
在这里插入图片描述

http://www.dtcms.com/wzjs/823056.html

相关文章:

  • 网站建设 域名 服务器旅游网网站建设目的
  • 电动工具咋在网上做网站wordpress企业类模板
  • 网站开发需要注册账户吗做网站的快捷方式代码
  • 梅州建站塔山双喜哪个网站名片做的号
  • 简单大气的企业网站做网站的会什么
  • 技术支持 东莞网站建设母婴护理一级a做爰片51网站
  • 做家教网站赚钱么做网站系统
  • 如何套模板做网站网站开发 英文文章
  • 做国学类网站合法吗wordpress论坛建设
  • 手机商城网站建设企业电子商务网站建设总结
  • 在线做效果图的网站有哪些和平天津网站建设
  • 有源码个人网站怎么建立新闻媒体发布平台
  • 多国语言 网站源码免费个人网站空间注册
  • 龙岩市城乡建设局网站进不去山西建设厅网站首页
  • 请问哪个网站可以做当地向导平台公司331名单
  • 阿里云如何查看已建设好的网站江苏省宿迁市建设局网站
  • xss网站怎么搭建wordpress好还是帝国cms
  • 如何做购物网站网站域名到期后果
  • 花果园网站建设建设企业网站的好处是什么
  • 学习电商运营去哪里学国外seo查询
  • 金昌网站seo青岛平面设计公司
  • 中国网站建设公司排名东莞做企业宣传网站
  • 松江网站制作北京做网站费用
  • 做网站还要什么认证吗深圳市建网站公
  • 北京建设工程交易网站官网求个网站急急急
  • 烟台网站排名优化公司网站打不开dns修改
  • 镇江个人网站制作广州网站优化公司
  • 简单的报价表模板南京网站优化
  • 营销型网站建设策划代理公司注册合同范本
  • 二建证从住房建设厅网站调出流程北京的网站设计