【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;
  }



目录
相关文章
|
6月前
|
移动开发 前端开发 Android开发
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
1105 12
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
6月前
|
移动开发 JavaScript 应用服务中间件
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
869 5
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
6月前
|
移动开发 Rust JavaScript
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
1020 4
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
6月前
|
移动开发 Android开发
【03】建立隐私关于等相关页面和内容-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【03】建立隐私关于等相关页面和内容-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
321 0
|
7月前
|
开发工具 Android开发
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
795 11
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
|
7月前
|
Java 开发工具 Maven
【01】完整的安卓二次商业实战-详细的初级步骤同步项目和gradle配置以及开发思路-优雅草伊凡
【01】完整的安卓二次商业实战-详细的初级步骤同步项目和gradle配置以及开发思路-优雅草伊凡
893 6
|
9月前
|
安全 数据库 Android开发
在Android开发中实现两个Intent跳转及数据交换的方法
总结上述内容,在Android开发中,Intent不仅是活动跳转的桥梁,也是两个活动之间进行数据交换的媒介。运用Intent传递数据时需注意数据类型、传输大小限制以及安全性问题的处理,以确保应用的健壯性和安全性。
593 11
|
JavaScript Linux 网络安全
Termux安卓终端美化与开发实战:从下载到插件优化,小白也能玩转Linux
Termux是一款安卓平台上的开源终端模拟器,支持apt包管理、SSH连接及Python/Node.js/C++开发环境搭建,被誉为“手机上的Linux系统”。其特点包括零ROOT权限、跨平台开发和强大扩展性。本文详细介绍其安装准备、基础与高级环境配置、必备插件推荐、常见问题解决方法以及延伸学习资源,帮助用户充分利用Termux进行开发与学习。适用于Android 7+设备,原创内容转载请注明来源。
3809 77
|
9月前
|
移动开发 Java 编译器
Kotlin与Jetpack Compose:Android开发生态的演进与架构思考
本文从资深Android工程师视角深入分析Kotlin与Jetpack Compose在Android系统中的技术定位。Kotlin通过空安全、协程等特性解决了Java在移动开发中的痛点,成为Android官方首选语言。Jetpack Compose则引入声明式UI范式,通过重组机制实现高效UI更新。两者结合不仅提升开发效率,更为跨平台战略和现代架构模式提供技术基础,代表了Android开发生态的根本性演进。
379 0
|
10月前
|
安全 Java Android开发
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡
447 0
为什么大厂要求安卓开发者掌握Kotlin和Jetpack?深度解析现代Android开发生态优雅草卓伊凡

热门文章

最新文章

下一篇
开通oss服务