基于FastAPI实现的Frida-RPC工具,自动解析JavaScript文件生成对应API接口
Go to file
想要成为RapStar吗? 8ce499c66a fix:完善说明文档
2020-09-24 16:24:29 +08:00
apps feat:frida对接多个app 2020-09-24 16:20:21 +08:00
source feat:frida对接多个app 2020-09-24 16:20:21 +08:00
utils feat:Base Demo实现 2020-09-24 15:11:47 +08:00
.gitignore feat:一点已经实现的小思路 2020-09-23 19:46:23 +08:00
config.py fix:完善说明文档 2020-09-24 16:24:29 +08:00
main.py feat:frida对接多个app 2020-09-24 16:20:21 +08:00
parse.js feat:Base Demo实现 2020-09-24 15:11:47 +08:00
README.md fix:完善说明文档 2020-09-24 16:24:29 +08:00
requirements.txt feat:Base Demo实现 2020-09-24 15:11:47 +08:00

Welcome to arida 👋

Version Documentation License: 暂无

基于FastAPI实现的Frida-RPC工具只需开发好相对应app的Frida-Js脚本,即可自动生成相应的基于FastAPIFrida-RPC工具

🏠 Homepage

Demo

Do By You Self

实现原理

Python执行PyexecJs通过Js的AST树结构获取Frida-Js脚本中rpc.exports的方法以及对应方法的参数个数,根据方法名和参数个数通过types.FunctionDefPython AST字节码来动态生成新的Function对象,并且结合pydanticcreate_model自动生成的参数模型注册到FastAPI的路由系统中,实现Frida-RPC的功能。

核心功能

  1. 对接多个AppRPC接口暴露

  2. 自动转化Js export方法变成接口

  3. 自动生成接口文档

Install

1. git clone git@github.com:lateautumn4lin/arida.git

2. conda create -n arida python==3.8

3. conda install --yes --file requirements.txt

Usage

1. uvicorn main:app --reload

2. watch 127.0.0.1:8000/docs 

eg:

生成的fastapi的api结构图

对应api的参数图

如何开发自己的接口呢?

  1. Config文件中写入自己的App信息

  2. Apps目录写开发相应的Frida-Js脚本,可参考其他两个文件

Run tests

uvicorn main:app --reload

测试Apk地址

1. https://www.wandoujia.com/apps/6612700

2. https://www.wandoujia.com/apps/7666802

eg:

测试图

参考资料

  1. https://www.cnblogs.com/olivetree123/p/5067685.htmlpython动态创建函数

  2. http://blog.soliloquize.org/2016/07/06/Python%E5%8A%A8%E6%80%81%E5%88%9B%E5%BB%BA%E5%87%BD%E6%95%B0/

  3. https://zhuanlan.zhihu.com/p/103665038python字节码

  4. https://www.jianshu.com/p/2006a8c75bb2FastAPI动态建模

  5. https://github.com/xonsh/xonsh/pull/3304/filespython AST解析参考

Author

👤 Lateautumn4lin

🤝 Contributing

Contributions, issues and feature requests are welcome!
Feel free to check issues page. You can also take a look at the contributing guide.

Show your support

Give a if this project helped you!

📝 License

Copyright © 2020 Lateautumn4lin.
This project is 暂无 licensed.


This README was generated with ❤️ by readme-md-generator