【Android 逆向】Android 逆向通用工具开发 ( Android 端远程命令工具 | Android 端可执行程序的 main 函数操作 | TCP 协议服务器建立 | 接收客户端数据 )

简介: 【Android 逆向】Android 逆向通用工具开发 ( Android 端远程命令工具 | Android 端可执行程序的 main 函数操作 | TCP 协议服务器建立 | 接收客户端数据 )

文章目录

前言

一、Android 端可执行程序的 main 函数操作

二、Android 端 TCP 协议服务器建立

三、Android 端接收 PC 端传来的数据

四、博客资源

前言

本篇博客重点分析 Android 端 运行的远程命令工具 remote 模块 ;


该 Android 远程端模块 是 Android 平台的可执行程序 , 使用 NDK 进行编译的可执行程序 , 配合 PC 端的工具进行内存修改 ;






一、Android 端可执行程序的 main 函数操作


Android 端可执行程序主函数的主体就是一个死循环 , 在该循环中 , 通过 TCP 协议 , 接收来自 PC 端的指令 , 根据不同的指令 , 执行不同的操作 ;



开始执行后 , 阻塞等待 PC 端连接 , 连接成功后 , 继续向后执行 ;


/* 等待 PC 端连接 , PC 端与 Android 端连接成功后 , 继续向后执行 */
  client.WaitForServer();


之后 , 还是阻塞等待 , 这次是等待 PC 端发送来的命令 ;


/* 等待 PC 端命令 */
client.WaitForCommand(root)


最后 , 根据获取的不同的命令 , 执行不同操作 , 这些操作 , 需要开发者自己进行开发 , 不同的应用 , 对应的操作也是不同的 ;



main 函数代码 :


int main()
{
  /* Android 端可执行程序主函数的主体就是一个死循环 , 
  * 在该循环中 , 通过 TCP 协议 , 接收来自 PC 端的指令 , 
  * 根据不同的指令 , 执行不同的操作
  */
  do {
  Client client;
  char data[] = HELLO_INFO;
  const char* pinfo = "client prepare done! wait for pc!  \n";
  DECRYPT(data, pinfo);
  printf("%s\n", data);
  printf("%s", pinfo);
  /* 等待 PC 端连接 , PC 端与 Android 端连接成功后 , 继续向后执行 */
  client.WaitForServer();
  /* 连接成功提示 */
  printf("get a connection!\n");
  Json::Value root;
  do {
    /* 等待 PC 端命令 */
    if (client.WaitForCommand(root) == 0) {
    switch (root["cmd"].asInt()) {
    case CMD_READ_DATA:
      root.clear();
      client.ReadData(root);
      break;
    case CMD_WRITE_GOLD:
      client.WriteGold(root);
      break;
    case CMD_WRITE_EXP:
      client.WriteExp(root);
      break;
    default:
      break;
    }
    }
    /* 如果连接断开 , 那么重置连接 , 继续等待用户连接 */
    else if (!client.isConnected()) {
    client.Reset();
    printf("connection is lost!\nretry!\n");
    break;
    }
  } while (client.isValid());
  } while (1);
  return 0;
}


Android 端可执行程序的 mian.c 代码位置 :


image.png






二、Android 端 TCP 协议服务器建立


从 TCP 网络协议角度看 , 在 Android 端运行的是 服务器端 , 在 PC 端运行的是 客户端 ;


Android 端的服务器建立 :


① 先绑定服务器 IP 地址 : 端口号

② 监听端口号

③ 阻塞等待客户端连接

PC 端的客户端 : 客户端只需要连接 绑定的服务器 IP 地址 + 端口号即可 ;



服务器建立代码 :


/* 建立服务器 
  * ① 先绑定服务器 IP 地址 : 端口号 
  * ② 监听端口号
  * ③ 阻塞等待客户端连接 
  * 客户端只需要连接 绑定的服务器 IP 地址 + 端口号即可
  */
  bool WaitForServer() {
  int ret = 0;
  struct sockaddr_in addr, client;
  addr.sin_family = AF_INET;
  addr.sin_port = 0x3725;//0x2537=9527
  /* 如果是 模拟器可以设置 127.0.0.1 , 
     如果是真机 , 需要填写局域网内真实 IP 地址 */
  addr.sin_addr.s_addr = inet_addr("127.0.0.1");
  /* 绑定 IP 地址 和 端口号 */
  ret = bind(m_socket, (sockaddr*)&addr, sizeof(sockaddr_in));
  if (ret < 0) {
    printf("error info:%d %s\n", errno, strerror(errno));
    return false;
  }
  /* 监听端口号 */
  ret = listen(m_socket, SOMAXCONN);
  if (ret < 0) {
    printf("error info:%d %s\n", errno, strerror(errno));
    return false;
  }
  char buffer[4096] = "";
  int size = sizeof(client);
  /* 阻塞等待客户端连接 */
  int c = accept(m_socket, (sockaddr*)&client, &size);
  if (c == INVALID_SOCKET) {
    return false;
  }
  m_client = c;
  return ret >= 0;
  }






三、Android 端接收 PC 端传来的数据


调用 recv 方法 , 阻塞接收 PC 端传输来的数据 , 然后解析 json 字符串 , 将解析结果保存到 command 中 ;



代码如下 :


/* 接收 PC 端传输来的数据 
  * 然后解析 json 字符串 
  * 将解析结果保存到 command 中
  */
  int WaitForCommand(Json::Value& command) {
  char buffer[4096] = "";
  int ret = recv(m_client, (void*)buffer, sizeof(buffer), 0);
  if (ret > 0) {
    ret = 0;
    Json::Reader reader;
    if (reader.parse(buffer, buffer + strlen(buffer), command)) {
    ret = 0;
    }
    else {
    ret = -1;
    }
  }
  else {
    close(m_client);
    m_client = INVALID_SOCKET;
  }
  return ret;
  }



目录
相关文章
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
1606 4
|
11月前
|
安全 数据库 Android开发
在Android开发中实现两个Intent跳转及数据交换的方法
总结上述内容,在Android开发中,Intent不仅是活动跳转的桥梁,也是两个活动之间进行数据交换的媒介。运用Intent传递数据时需注意数据类型、传输大小限制以及安全性问题的处理,以确保应用的健壯性和安全性。
662 11
|
存储 XML Java
Android 文件数据储存之内部储存 + 外部储存
简介:本文详细介绍了Android内部存储与外部存储的使用方法及核心原理。内部存储位于手机内存中,默认私有,适合存储SharedPreferences、SQLite数据库等重要数据,应用卸载后数据会被清除。外部存储包括公共文件和私有文件,支持SD卡或内部不可移除存储,需申请权限访问。文章通过代码示例展示了如何保存、读取、追加、删除文件以及将图片保存到系统相册的操作,帮助开发者理解存储机制并实现相关功能。
2896 2
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
989 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
JSON Java Android开发
Android 开发者必备秘籍:轻松攻克 JSON 格式数据解析难题,让你的应用更出色!
【8月更文挑战第18天】在Android开发中,解析JSON数据至关重要。JSON以其简洁和易读成为首选的数据交换格式。开发者可通过多种途径解析JSON,如使用内置的`JSONObject`和`JSONArray`类直接操作数据,或借助Google提供的Gson库将JSON自动映射为Java对象。无论哪种方法,正确解析JSON都是实现高效应用的关键,能帮助开发者处理网络请求返回的数据,并将其展示给用户,从而提升应用的功能性和用户体验。
445 1
|
存储 大数据 数据库
Android经典面试题之Intent传递数据大小为什么限制是1M?
在 Android 中,使用 Intent 传递数据时存在约 1MB 的大小限制,这是由于 Binder 机制的事务缓冲区限制、Intent 的设计初衷以及内存消耗和性能问题所致。推荐使用文件存储、SharedPreferences、数据库存储或 ContentProvider 等方式传递大数据。
912 0
|
存储 缓存 Java
Android项目架构设计问题之优化业务接口数据的加载效率如何解决
Android项目架构设计问题之优化业务接口数据的加载效率如何解决
210 0
|
8月前
|
移动开发 前端开发 Android开发
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
1422 12
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
8月前
|
移动开发 JavaScript 应用服务中间件
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
1018 5
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
8月前
|
移动开发 Rust JavaScript
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
1117 4
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡

热门文章

最新文章