爬虫利器:Frida Rpc算法转发

本章来给大家介绍一个爬虫利器,嗯。。。,app协议还原利器更合适,当然,自己用的话是利器,别人用是折磨,因为它需要依赖模拟器或手机。对于环境来说是有些麻烦的!

这个东西我们一般称它为frida rpc算法转发。

为什么使用rpc算法转发

我们都知道现在开发app主流的方案是Java,一些中大厂app是Java+C++,C++最后生成的是so,是arm汇编。

一般分析arm汇编才是最难的,所以中大厂会更倾向把重要加密放在so中,来增强爬虫或者破解的难度!!!

但是如果使用rpc的话,你就不太需要分析繁琐的Java层和so层的加密了!

你需要通过frida主动调用Java层或so层的方法,然后拿到被加密的内容,然后其他的操作不是就可以为所欲为了?

环境

pixel2v10(已root)
Magiskv23.0
Charlesv4.6.2
Dronyv1.3.154
Pythonv3.8.6
fridav14.2.18

rpc转发案例

本次使用的app是嘟嘟牛,百年只刚嘟嘟牛,哈哈哈!

抓包

通过抓包发现,走的接口是http://api.dodovip.com/api/user/login

提交的是一个Encrypt:xxxx,返回的是一串字符串,这???啥玩意???

所以我们要模拟这个请求,必定要捋清这个请求和响应是怎么生成的!

分析

app拖入jadx中,搜索关键字Encrypt:

主要加密逻辑在这一块:

分析不是这一章的重点,相关hook代码,稍微研究一下就懂了!

Java.perform(function () {

functionprintMap2(map) {
returnJava.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
letresult=this.encodeDesMap(data, desKey, desIV)
console.log("RequestUtil encodeDesMap result:", result)

returnresult
}


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)
letresult=this.paraMap(addMap, append, sign)
console.log("RequestUtil paraMap result:", result)

returnresult
}

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)
letresult=this.decodeDesJson(json, desKey, desIV)
console.log("RequestUtil decodeDesJson result:", result)

returnresult
}


})

整理

根据上述hook,整理出来主动调用应该是这样调用的,一个加密,一个解密。

//请求加密
functioncallparaMap(username, userPwd, timeStamp) {
letresult="";
Java.perform(function () {
letmap=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)
//
letr1=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)
})
returnresult;

}
//响应加密
functioncalldecodedesjson(data) {
letresult="";
Java.perform(function () {
result=Java.use("com.dodonew.online.http.RequestUtil").decodeDesJson(data, "65102933", "32028092")
// console.log("decode:", decode)
})
returnresult;
}

搭建服务

既然上述已经把逻辑捋清楚了,并且也已经写好的主动调用的js代码。

那么就来了,如何和python结合到一起,跑成一个web,这样爬虫只需要响应的参数拿到返回值即可。

代码​:

fromfastapiimportFastAPI
importuvicorn
importfrida

jsCode="""
functioncallparamap(username, userPwd, timeStamp) {
letresult="";
Java.perform(function () {
letmap=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)
//
letr1=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)
})
returnresult;

}

functioncalldecodedesjson(data) {
letresult="";
Java.perform(function () {
result=Java.use("com.dodonew.online.http.RequestUtil").decodeDesJson(data, "65102933", "32028092")
// console.log("decode:", decode)
})
returnresult;
}
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&timestamp=1647662720061
@app.get("/getencrypt")
asyncdefgetencrypt(username, password, timestamp):
result=script.exports.encrypt(username, password, timestamp)
return {"data": result}


frompydanticimportBaseModel


classItem(BaseModel):
data: str


@app.post("/getdecode")
asyncdefgetdecode(item: Item):
result=script.exports.decode(item.data)
return {"data": result}


if__name__=='__main__':
uvicorn.run(app, port=8080)

运行:

构造请求

代码:

importrequests
importtime
importjson

dt=time.time() *1000

# 请求加密
url=f"http://127.0.0.1:8080/getencrypt?username=18903916120&password=1111&timestamp={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)

运行:

总结

这个app还是很简单的,但是应该用到了俩加密,如果要是硬刚代码的话,还是需要研究研究的。

但是如果使用rpc这种转发方案的话,你就可以发现几行代码就完事了!

但是缺陷也是明显的,需要依赖电脑和手机,如果只是采集数据的话,应该还是挺合适的!

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/122719.html<

(0)
运维的头像运维
上一篇2025-02-22 11:39
下一篇 2025-02-22 11:40

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注