6.RPC远程调用

什么是RPC

RPC:Remote(远程)Procedure(过程|流程)Call(调用) 远程调用

特性: 多主机,多手机,多端口混连

互联互通

动态修改

远程调动

javascript_demo

function invoke(){
    Java.perform(function(){
        Java.use("com.example.project_2.MainActivity").fun.overload('java.lang.String').implementation = function(s1){
            var send_data = s1.toString()
            var result_data;
            //send 向 python 发送数据
            send(send_data)
            //接收python返回的数据
            recv(function(recv_data){
                console.log(recv_data)
                result_data = Java.use("java.lang.String").$new(recv_data.str_data);
                // result_data = recv_data.str_data;
                // console.log(result_data)
            }).wait();
            var result = this.fun(result_data)
            return result
        }    
    })
}
//这里是rpc调用的方法
rpc.exports = {
    invokefunc:invoke
}

python_demo

import time
import frida

 #消息处理函数

def my_message_handler(message,payload):
    print(message)
    # print(payload)
    if message['type']=='send':
        msg = message['payload']+"66666"
        print(msg)
        script.post({"str_data":msg})

                                            
#用USB方式连接手机                                                                                                                                   
# device = frida.get_usb_device()
#用非标准端口的方式连接手机
device = frida.get_device_manager().add_remote_device("192.168.50.138:8888")

#打印设备应用
print(device.enumerate_applications)
print(device.enumerate_processes)
# pid = device.spawn(["com.example.project_2"])
# device.resume
# time.sleep(1)
# session = device.attach(pid)
#与app连接,注入
session = device.attach("com.example.project_2")
#加载 frida hook 脚本  就是上面的代码
with open("demo_7.js","r") as f:
    #创建hook脚本

    script = session.create_script(f.read())
#监听message        
script.on("message",my_message_handler)
#加载脚本
script.load()


command = ""
while True :
    command = input("Enter Command:")
    if command == "1":
        break
    elif command =="2":
        #调用在JavaScript 定义的invokefunc() 方法
        script.exports.invokefunc()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值