当前位置: 首页 > news >正文

iOS 逆向学习 - iOS Architecture Cocoa Touch Layer

iOS 逆向学习 - iOS Architecture Cocoa Touch Layer

      • 一、Cocoa Touch Layer 简介
      • 二、Cocoa Touch Layer 的核心功能
        • 1. UIKit
        • 2. Event Handling(事件处理)
        • 3. Multitasking(多任务处理)
        • 4. Push Notifications(推送通知)
        • 5. Social Media Integration(社交媒体集成)
      • 三、Cocoa Touch Layer 相关联的概念
        • 1. Framework 的封装
        • 2. 动态库和符号
        • 3. Objective-C 运行时
      • 四、逆向开发中关注的 Cocoa Touch 层细节
      • 五、总结

一、Cocoa Touch Layer 简介

在这里插入图片描述
Cocoa Touch Layer 是 iOS 操作系统的顶层架构,专门为开发者提供构建应用程序的高层次框架。它主要负责用户交互界面(UI)、事件处理、多任务处理和系统服务的整合。作为 iOS 应用开发的核心,Cocoa Touch Layer 封装了许多便捷的工具和 API,使开发者能够快速创建直观、高性能的应用程序。

在逆向开发中,深入理解 Cocoa Touch Layer 的架构和工作原理,是分析应用功能、界面交互及事件流的基础。


二、Cocoa Touch Layer 的核心功能

1. UIKit
  • 功能
    • UIKit 是 iOS 开发的核心框架,提供了用于构建用户界面的一切工具,包括按钮、标签、表格视图等。
    • 它还支持屏幕旋转、手势识别、动画等交互功能。
  • 常用类
    • UIView:所有视图的基础类。
    • UIViewController:控制视图逻辑的核心类。
    • UITableViewUICollectionView:构建列表或网格视图。
    • UIButtonUILabel:基础控件。
  • 逆向开发中的用途
    • 分析 UI 元素的层次结构(使用工具如 Reveal 或 IDA)。
    • 修改界面布局和交互逻辑。

2. Event Handling(事件处理)
  • 功能
    • 管理触摸事件(如点击、滑动、长按等)。
    • 处理运动事件(设备旋转、重力感应)。
    • 支持远程控制事件(如耳机按钮事件)。
  • 关键机制
    • Responder Chain(响应链):事件沿着视图层次结构传递,直到被某个对象处理。
    • Gesture Recognizers:简化了触摸事件处理,例如 UIPinchGestureRecognizer(缩放手势)。
  • 逆向开发中的用途
    • 修改或拦截事件响应逻辑(通过 Hook 方法如 touchesBegan)。
    • 分析用户交互行为。

3. Multitasking(多任务处理)
  • 功能
    • 允许应用在后台执行任务(如音乐播放、下载)。
    • 管理后台通知与更新。
  • 关键机制
    • UIApplicationDelegate 提供了相关生命周期方法(如 applicationDidEnterBackground)。
    • 后台任务由 beginBackgroundTask 管理。
  • 逆向开发中的用途
    • 分析后台任务的运行逻辑。
    • Hook 生命周期方法,了解应用如何管理多任务。

4. Push Notifications(推送通知)
  • 功能
    • 允许服务器向用户发送通知,显示重要信息或事件。
    • 分为本地通知和远程推送通知(通过 Apple Push Notification Service)。
  • 关键机制
    • UNUserNotificationCenter:用于管理通知。
    • didReceiveRemoteNotification:处理远程通知的方法。
  • 逆向开发中的用途
    • Hook 推送处理逻辑,分析通知内容和交互行为。
    • 绕过通知权限弹窗或模拟通知数据。

5. Social Media Integration(社交媒体集成)
  • 功能
    • 提供与社交媒体(如 Facebook、Twitter)的直接交互。
    • 支持应用间数据共享和登录。
  • 逆向开发中的用途
    • 分析第三方 SDK 的集成逻辑(如 Facebook SDK)。
    • 修改社交媒体登录的行为。

三、Cocoa Touch Layer 相关联的概念

1. Framework 的封装

Cocoa Touch Layer 是一个封装了多层功能的高层次框架,结合了其他 iOS 层(如 Core Services 和 Core OS)的能力:

  • Core Services 提供底层功能(如 SQLite 数据库、网络通信)。
  • Core OS 负责底层硬件交互(如内存、线程管理)。
2. 动态库和符号
  • UIKit 和其他 Cocoa Touch 框架以动态库(.dylib.framework)的形式存在。
  • 在逆向分析中,通过查看符号表(Symbol Table)可以找到相关的类、方法和属性。
3. Objective-C 运行时
  • Cocoa Touch Layer 的大部分功能基于 Objective-C 实现,其动态运行时特性(如消息发送、类和方法动态绑定)是逆向分析的重点。

四、逆向开发中关注的 Cocoa Touch 层细节

  1. UI 层次结构分析

    • 工具:RevealFlex,用来查看应用的视图层次。
    • 常见目标:修改界面元素的属性或布局。
  2. Hook UIKit 方法

    • 通过工具(如 LogosFishhook)拦截和修改 UIKit 中的关键方法。
    • 示例:Hook viewDidLoad 来分析视图加载逻辑。
  3. 触摸事件拦截

    • Hook touchesBegantouchesMoved 等方法,分析和修改事件处理流程。
  4. 动态注入与调试

    • 使用工具如 CycriptFrida 动态调试 UIKit 代码。

五、总结

Cocoa Touch Layer 是 iOS 应用程序的核心开发层,涵盖了用户界面、事件处理、通知、多任务等关键功能。对于逆向开发来说,掌握 Cocoa Touch Layer 的原理和框架结构,可以帮助深入了解目标应用的行为和功能逻辑,同时为修改界面、分析事件流和 Hook 系统调用奠定基础。

相关文章:

iOS 逆向学习 - iOS Architecture Cocoa Touch Layer

iOS 逆向学习 - iOS Architecture Cocoa Touch Layer 一、Cocoa Touch Layer 简介二、Cocoa Touch Layer 的核心功能1. UIKit2. Event Handling(事件处理)3. Multitasking(多任务处理)4. Push Notifications(推送通知&…...

C语言实现库函数strlen

size_t是 unsigned int fgets会读入\n&#xff0c;用strcspn函数除去 assert判读指针是否为空指针&#xff0c;使用前要引头文件<assert.h> #include <stdio.h> #include <assert.h> size_t mystrlen(const char* str) {assert(str);size_t count 0;while …...

050_小驰私房菜_MTK Camera debug, data rate 、mipi_pixel_rate 确认

mipi_pixel_rate = data rate * 4 / 10 (4 是表示4lane,10表示raw数据是10bit) mipi_pixel_rate 信息,我们可以通过 sentest命令打印看到: 下面的信息我们可以看到,mipi_pixel_rate = 501.357739Mpps,mipi rate = 10000000,是对应的我们驱动文件里面配置写的mipi_pixel_r…...

(六)vForm 动态表单(数据量大,下拉选卡顿问题)

系列文章目录 (一)vForm 动态表单设计器之使用 (二)vForm 动态表单设计器之下拉、选择 (三)vForm 动态表单解决下拉框无数据显示id问题 (四)vForm 动态表单自定义组件、属性 (五)vForm 动态表单文件上传、下载 文章目录 目录 前言 一、组件改造 1.添加分页所需参…...

【mybatis-plus问题集锦系列】mybatis使用xml配置文件实现数据的基础增删改查

简单的数据查询&#xff0c;我们可以在mapper接口里面去实现&#xff0c;但是如果是复杂的查询&#xff0c;我们就可以使用xml配置文件去做&#xff0c; 官网链接xml配置文件 实现效果 实现代码 根据mapper接口的包结构&#xff0c;在resources包里面新建同名同结构的xml文件…...

投稿指南【NO.12_14】【极易投中】期刊投稿(毛纺科技)

近期有不少同学咨询投稿期刊的问题&#xff0c;大部分院校的研究生都有发学术论文的要求&#xff0c;少部分要求高的甚至需要SCI或者多篇核心期刊论文才可以毕业&#xff0c;但是核心期刊要求论文质量高且审稿周期长&#xff0c;所以本博客梳理一些计算机特别是人工智能相关的期…...

机器学习算法的分类

一、按学习方式分类 1.监督学习&#xff08;Supervised Learning&#xff09; &#xff08;1&#xff09;定义&#xff1a;使用已标记的数据进行训练&#xff0c;每个输入数据都有对应的输出标签。模型学习输入与输出之间的映射关系。 按以上可以分为以下两种&#xff1a; …...

Linux操作系统下,挂ILA

一、在linux下安装vivado2018.3 参考视频&#xff1a;Linux下vivado安装教程_哔哩哔哩_bilibili 复制安装包进入虚拟机 安装包链接&#xff1a;https://pan.quark.cn/s/ca1a15d446fa 我的vmware tools无法使用&#xff0c;不能直接拖进虚拟机&#xff0c;所以使用了U盘复制…...

HTML——26.像素单位

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title>像素</title></head><body><!--像素&#xff1a;1.指设备屏幕上的一个点&#xff0c;单位px&#xff0c;如led屏上的小灯朱2.当屏幕分辨率固定时&…...

【HTML】Day02

【HTML】Day02 1. 列表标签1.1 无序列表1.2 有序列表1.3 定义列表 2. 表格标签2.1 合并单元格 3. 表单标签3.1 input标签基本使用3.2 上传多个文件 4. 下拉菜单、文本域5. label标签6. 按钮button7. div与span、字符实体字符实体 1. 列表标签 作用&#xff1a;布局内容排列整齐…...

AI 自动化编程对编程教育的影响

AI 自动化编程的未来 引言 你是否曾想过&#xff0c;未来的程序员需要掌握哪些技能呢&#xff1f;随着人工智能的迅猛发展&#xff0c;特别是生成式AI工具的普及&#xff0c;编程的世界正在发生翻天覆地的变化。编程教育也在这种环境下进行着深刻的转型。那么&#xff0c;AI …...

Java100道面试题

1.JVM内存结构 VM内存结构指的是JVM运行时数据区结构&#xff0c;它主要包含以下几个部分&#xff1a; 堆&#xff08;Heap&#xff09;&#xff1a;线程共享。 JVM堆&#xff08;Heap&#xff09;是Java虚拟机中的一块内存区域&#xff08;所有线程共享&#xff09;&#x…...

解密人工智能:如何改变我们的工作与生活

引言&#xff1a;AI崛起背后的思考 在过去的几十年里&#xff0c;人工智能&#xff08;AI&#xff09;从科幻小说中的神秘存在&#xff0c;逐渐走进了我们的日常生活。无论是智能手机的语音助手&#xff0c;还是推荐心仪商品的电商平台&#xff0c;AI技术已悄然融入工作与生活的…...

Linux postgresql-15部署文档

一、PostgreSQL的安装 1、下载地址 postgresql安装包下载地址&#xff1a;https://www.postgresql.org/download/linux/redhat/ 2、安装脚本 复制下面的安装脚本即可&#xff1a; sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64…...

visual studio 安全模式

一、安全模式&#xff1a; 在 Visual Studio 中&#xff0c;安全模式是一种启动方式&#xff0c;允许你在禁用所有扩展和自定义设置的情况下启动 Visual Studio。这个模式可以帮助排除插件或扩展引起的问题&#xff0c;特别是在 Visual Studio 无法正常启动时。 二、安全模式下…...

Pandas-timestamp和datetime64的区别

文章目录 1. Timestamp&#xff08;时间戳&#xff09;2. Datetime64&#xff08;日期时间64位&#xff09;3. 主要区别&#xff1a; pandas.Timestamp 和 pandas.Datetime64 都是用于表示日期和时间的 Pandas 对象&#xff0c;但它们有一些关键的区别&#xff1a; 1. Timesta…...

@MapperScan

简介&#xff1a; MapperScan注解是MyBatis框架在Spring Boot中的一个重要集成注解 作用&#xff1a; MapperScan主要作用是告诉Spring框架在启动时扫描指定的包路径&#xff0c;并将该路径下的所有MyBatis的Mapper接口批量注入到Spring容器中。这样&#xff0c;开发者就可以…...

SQL中聚类后字段数据串联字符串方法研究

在 SQL 中&#xff0c;使用 聚类&#xff08;GROUP BY&#xff09; 后将某个字段的数据串联为一个字符串&#xff0c;常见的方法包括以下几种&#xff0c;取决于数据库管理系统&#xff08;DBMS&#xff09;的具体支持功能&#xff1a; 1. 使用 GROUP_CONCAT &#xff08;MySQL…...

【嵌入式硬件】直流电机驱动相关

项目场景&#xff1a; 驱动履带车&#xff08;双直流电机&#xff09;前进、后退、转弯 问题描述 电机驱动MOS管烧毁 电机驱动采用IR2104STRH1R403NL的H桥方案&#xff08;这是修改之后的图&#xff09; 原因分析&#xff1a; 1.主要原因是4路PWM没有限幅&#xff0c;修改…...

CSP初赛知识学习计划(第一天)

计算机知识全解析 一、计算机的发展历程 计算机的发展堪称一部波澜壮阔的科技史诗&#xff0c;其源头可追溯至古老的计算工具。早期&#xff0c;为了满足人类在天文、历法计算以及商业贸易中对数据处理的需求&#xff0c;算盘、算筹等手动计算器械应运而生&#xff0c;它们依…...

挑战杯推荐项目

“人工智能”创意赛 - 智能艺术创作助手&#xff1a;借助大模型技术&#xff0c;开发能根据用户输入的主题、风格等要求&#xff0c;生成绘画、音乐、文学作品等多种形式艺术创作灵感或初稿的应用&#xff0c;帮助艺术家和创意爱好者激发创意、提高创作效率。 ​ - 个性化梦境…...

(十)学生端搭建

本次旨在将之前的已完成的部分功能进行拼装到学生端&#xff0c;同时完善学生端的构建。本次工作主要包括&#xff1a; 1.学生端整体界面布局 2.模拟考场与部分个人画像流程的串联 3.整体学生端逻辑 一、学生端 在主界面可以选择自己的用户角色 选择学生则进入学生登录界面…...

反向工程与模型迁移:打造未来商品详情API的可持续创新体系

在电商行业蓬勃发展的当下&#xff0c;商品详情API作为连接电商平台与开发者、商家及用户的关键纽带&#xff0c;其重要性日益凸显。传统商品详情API主要聚焦于商品基本信息&#xff08;如名称、价格、库存等&#xff09;的获取与展示&#xff0c;已难以满足市场对个性化、智能…...

前端倒计时误差!

提示:记录工作中遇到的需求及解决办法 文章目录 前言一、误差从何而来?二、五大解决方案1. 动态校准法(基础版)2. Web Worker 计时3. 服务器时间同步4. Performance API 高精度计时5. 页面可见性API优化三、生产环境最佳实践四、终极解决方案架构前言 前几天听说公司某个项…...

【第二十一章 SDIO接口(SDIO)】

第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...

376. Wiggle Subsequence

376. Wiggle Subsequence 代码 class Solution { public:int wiggleMaxLength(vector<int>& nums) {int n nums.size();int res 1;int prediff 0;int curdiff 0;for(int i 0;i < n-1;i){curdiff nums[i1] - nums[i];if( (prediff > 0 && curdif…...

ElasticSearch搜索引擎之倒排索引及其底层算法

文章目录 一、搜索引擎1、什么是搜索引擎?2、搜索引擎的分类3、常用的搜索引擎4、搜索引擎的特点二、倒排索引1、简介2、为什么倒排索引不用B+树1.创建时间长,文件大。2.其次,树深,IO次数可怕。3.索引可能会失效。4.精准度差。三. 倒排索引四、算法1、Term Index的算法2、 …...

智能仓储的未来:自动化、AI与数据分析如何重塑物流中心

当仓库学会“思考”&#xff0c;物流的终极形态正在诞生 想象这样的场景&#xff1a; 凌晨3点&#xff0c;某物流中心灯火通明却空无一人。AGV机器人集群根据实时订单动态规划路径&#xff1b;AI视觉系统在0.1秒内扫描包裹信息&#xff1b;数字孪生平台正模拟次日峰值流量压力…...

LeetCode - 199. 二叉树的右视图

题目 199. 二叉树的右视图 - 力扣&#xff08;LeetCode&#xff09; 思路 右视图是指从树的右侧看&#xff0c;对于每一层&#xff0c;只能看到该层最右边的节点。实现思路是&#xff1a; 使用深度优先搜索(DFS)按照"根-右-左"的顺序遍历树记录每个节点的深度对于…...

GO协程(Goroutine)问题总结

在使用Go语言来编写代码时&#xff0c;遇到的一些问题总结一下 [参考文档]&#xff1a;https://www.topgoer.com/%E5%B9%B6%E5%8F%91%E7%BC%96%E7%A8%8B/goroutine.html 1. main()函数默认的Goroutine 场景再现&#xff1a; 今天在看到这个教程的时候&#xff0c;在自己的电…...