您现在的位置是:人工智能 >>正文
爬虫利器:Frida Rpc算法转发
人工智能84人已围观
简介本章来给大家介绍一个爬虫利器,嗯。。。,app协议还原利器更合适,当然,自己用的话是利器,别人用是折磨,因为它需要依赖模拟器或手机。对于环境来说是有些麻烦的!这个东西我们一般称它为frida rpc算 ...

本章来给大家介绍一个爬虫利器,爬虫嗯。利器。算法 。爬虫,利器app协议还原利器更合适,算法当然,爬虫自己用的利器话是利器,别人用是算法折磨 ,因为它需要依赖模拟器或手机 。爬虫对于环境来说是利器有些麻烦的 !
这个东西我们一般称它为frida rpc算法转发 。模板下载算法
为什么使用rpc算法转发我们都知道现在开发app主流的爬虫方案是Java ,一些中大厂app是利器Java+C++ ,C++最后生成的算法是so,是arm汇编 。
一般分析arm汇编才是最难的,所以中大厂会更倾向把重要加密放在so中 ,来增强爬虫或者破解的难度!建站模板!!
但是如果使用rpc的话 ,你就不太需要分析繁琐的Java层和so层的加密了 !
你需要通过frida主动调用Java层或so层的方法,然后拿到被加密的内容,然后其他的操作不是就可以为所欲为了?
环境 复制pixel2 v10(已root)
Magisk v23.0Charles v4.6.2Drony v1.3.154Python v3.8.6frida v14.2.181.2.3.4.5.6. rpc转发案例本次使用的app是高防服务器嘟嘟牛,百年只刚嘟嘟牛,哈哈哈!
抓包通过抓包发现,走的接口是http://api.dodovip.com/api/user/login

提交的是一个Encrypt:xxxx ,返回的是一串字符串,这 ???啥玩意 ? ??
所以我们要模拟这个请求,必定要捋清这个请求和响应是怎么生成的 !云计算
分析app拖入jadx中,搜索关键字Encrypt :

主要加密逻辑在这一块:

分析不是这一章的重点 ,相关hook代码 ,稍微研究一下就懂了!
复制Java.perform(function() {
function printMap2(map) {
return Java.cast(map, Java.use("java.util.HashMap"));
}
// Java.use("com.dodonew.online.http.RequestUtil").encodeDesMap.overload(java.lang.String, java.lang.String, java.lang.String).implementation = function (data, desKey, desIV) {
console.log("RequestUtil encodeDesMap is call")
console.log("data:", data)
console.log("desKey:", desKey)//65102933 console.log("desIV:", desIV)//32028092 let result = this.encodeDesMap(data, desKey, desIV)
console.log("RequestUtil encodeDesMap result:", result)
return result}
Java.use("com.dodonew.online.http.RequestUtil").paraMap.overload(java.util.Map, java.lang.String, java.lang.String).implementation = function (addMap, append, sign) {
console.log("RequestUtil paraMap is call")
console.log("addMap:", addMap)
console.log("addMap:", printMap2(addMap))
console.log("append:", append)
console.log("sign:", sign)
let result = this.paraMap(addMap, append, sign)
console.log("RequestUtil paraMap result:", result)
return result}
Java.use("com.dodonew.online.http.RequestUtil").decodeDesJson.implementation = function (json, desKey, desIV) {
console.log("RequestUtil decodeDesJson is call")
console.log("json:", json)
console.log("desKey:", desKey)
console.log("desIV:", desIV)
let result = this.decodeDesJson(json, desKey, desIV)
console.log("RequestUtil decodeDesJson result:", result)
return result}
})1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.39.40.41.42.43.44. 整理根据上述hook ,整理出来主动调用应该是这样调用的 ,一个加密,一个解密。
复制//请求加密function callparaMap(username, userPwd, timeStamp) {
let result = "";
Java.perform(function() {
let map = Java.use("java.util.HashMap").$new();
map.put("timeStamp", timeStamp)
map.put("loginImei", "Androidnull")
map.put("equtype", "ANDROID")
map.put("userPwd", userPwd)
map.put("username", username)
// let r1 = Java.use("com.dodonew.online.http.RequestUtil").paraMap(map, "sdlkjsdljf0j2fsjk", "sign")
// console.log("r1:", r1) // result = Java.use("com.dodonew.online.http.RequestUtil").encodeDesMap(r1, "65102933", "32028092")
// console.log("r2:", r2)})
return result;
}
//响应加密function calldecodedesjson(data) {
let result = "";
Java.perform(function() {
result = Java.use("com.dodonew.online.http.RequestUtil").decodeDesJson(data, "65102933", "32028092")
// console.log("decode:", decode)})
return result;
}1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29. 搭建服务既然上述已经把逻辑捋清楚了,并且也已经写好的主动调用的js代码。免费模板
那么就来了,如何和python结合到一起,跑成一个web,这样爬虫只需要响应的参数拿到返回值即可。
代码:
复制from fastapi import FastAPIimport uvicornimport fridajsCode = """ function callparamap(username, userPwd, timeStamp) {
let result = "";
Java.perform(function() {
let map = Java.use("java.util.HashMap").$new();
map.put("timeStamp", timeStamp)
map.put("loginImei", "Androidnull")
map.put("equtype", "ANDROID")
map.put("userPwd", userPwd)
map.put("username", username)
// let r1 = Java.use("com.dodonew.online.http.RequestUtil").paraMap(map, "sdlkjsdljf0j2fsjk", "sign")
// console.log("r1:", r1) // result = Java.use("com.dodonew.online.http.RequestUtil").encodeDesMap(r1, "65102933", "32028092")
// console.log("r2:", r2)})
return result;
}
function calldecodedesjson(data) {
let result = "";
Java.perform(function() {
result = Java.use("com.dodonew.online.http.RequestUtil").decodeDesJson(data, "65102933", "32028092")
// console.log("decode:", decode)})
return result;
}
rpc.exports ={
encrypt: callparamap,
decode: calldecodedesjson,
};
"""# 准备工作# process = frida.get_device_manager().add_remote_device(192.168.3.68:27042).attach("com.dodonew.online")
process = frida.get_usb_device().attach(com.dodonew.online)
script = process.create_script(jsCode)
print([*] Running 小肩膀)
script.load()
app = FastAPI()
# http://127.0.0.1:8080/getencrypt?username=18903916120&password=1111×tamp=1647662720061@app.get("/getencrypt")
async def getencrypt(username, password, timestamp):
result = script.exports.encrypt(username, password, timestamp)
return { "data": result}
from pydantic import BaseModelclass Item(BaseModel):
data: str@app.post("/getdecode")
async def getdecode(item: Item):
result = script.exports.decode(item.data)
return { "data": result}
if __name__ == __main__:
uvicorn.run(app, port=8080)1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.39.40.41.42.43.44.45.46.47.48.49.50.51.52.53.54.55.56.57.58.59.60.61.62.63.64.65.66.67.68.69.70.运行:

代码 :
复制import requestsimport timeimport jsondt = time.time() * 1000# 请求加密url = f"http://127.0.0.1:8080/getencrypt?username=18903916120&password=1111×tamp={ dt}"r1 = requests.get(url)
print(r1.json())
# 登录url = "http://api.dodovip.com/api/user/login"headers ={
"Content-Type": "application/json;charset=utf-8"}
data ={
"Encrypt": r1.json().get("data")
}
print(data)
r = requests.post(url=url, headers=headers, data=json.dumps(data))
print(r.text)
# 拿到请求解密data ={
"data": r.text}
url = "http://127.0.0.1:8080/getdecode"r = requests.post(url=url,headers=headers, data=json.dumps(data))
print(r.text)1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.运行:

这个app还是很简单的,但是应该用到了俩加密 ,如果要是硬刚代码的话 ,还是需要研究研究的。亿华云
但是如果使用rpc这种转发方案的话 ,你就可以发现几行代码就完事了 !
但是缺陷也是明显的,需要依赖电脑和手机 ,如果只是采集数据的话 ,应该还是挺合适的 !
Tags:
转载:欢迎各位朋友分享到网络,但转载请说明文章出处“算法与编程”。http://www.bzli.cn/news/147e799845.html
相关文章
APT 28组织成员被指控入侵北约智库
人工智能Security Affairs 网站披露,德国检察官对名为 Nikolaj Kozachek 的俄罗斯黑客发出了逮捕令,该名黑客被指控对位于德国的北约智库联合空中力量能力中心进行了网络间谍攻击。据悉 ...
【人工智能】
阅读更多华为天际通(探索5G通信时代的智能互联未来)
人工智能随着5G技术的不断进步,华为天际通作为一种新兴的通信方式,正逐渐引起人们的关注。本文将从多个方面介绍华为天际通的特点和应用,并探讨其在未来智能互联时代的潜力。华为天际通的起源和背景华为天际通作为华为公 ...
【人工智能】
阅读更多探索AMD760CPU的强大性能和先进技术(一款突破性的处理器,重新定义计算体验)
人工智能随着科技的不断发展,计算机处理器的性能也得到了极大的提升。AMD760CPU作为一款突破性的处理器,拥有出色的性能和先进的技术,为用户带来了全新的计算体验。本文将深入探讨AMD760CPU的各项特点和 ...
【人工智能】
阅读更多
热门文章
最新文章
友情链接
- 小米Note2(小米Note2在市场上受到广泛关注,销量持续飙升)
- 索尼Z5尊享音质全面解析(探究索尼Z5尊享音质的突破之处)
- 探索Nowallprime的性(无墙壁体验的未来——Nowallprime的突破性创新)
- BugooG1(探索BugooG1的卓越性能和创新设计)
- 红米Note4在知乎上的评价如何?(通过知乎用户的真实评价了解红米Note4的性能、使用体验及优缺点)
- 第七代i57500的卓越表现(一款出色的处理器推动电脑性能提升)
- 优沃IWM智能体重管理系统——轻松掌控健康(健康管理新利器——优沃IWM帮你实现身体管理的新高度)
- SupremeFXS1220音效技术评测(探索SupremeFXS1220音效芯片的卓越性能与创新功能)
- HTC M8口袋模式如何开启 b2b信息平台源码库亿华云网站建设企业服务器云服务器香港物理机