前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【产品那些事】固件安全-关于OTA升级包分析

【产品那些事】固件安全-关于OTA升级包分析

作者头像
今天是几号
发布2024-07-18 15:10:32
1030
发布2024-07-18 15:10:32
举报
文章被收录于专栏:Cyber Security

前言

什么是OTA?

OTA(Over-the-Air)是一种通过无线通信网络(如Wi-Fi、蜂窝网络)远程下载和安装设备固件或软件更新的方式。这种方式广泛应用于智能手机、物联网设备、汽车电子等领域。 小米发烧友估计对此并不陌生,线刷、卡刷、各种系统的刷机包,最近的澎湃OS不知道各位米友试着刷了没有。当然还有路由器、汽车,甚至台灯等各种智能家居,都是通过OTA的方式进行升级更新。 这里笔者通过两个固件解压包分析案例,来学习固件安全相关内容。

升级包(固件)的类型和架构

二进制映像(.bin):最常见的固件格式,包含了设备运行所需的所有代码和数据,通常用于路由器、摄像头、物联网设备等。 压缩包(.zip, .tar, .gz, .xz):将多个文件打包并压缩成一个文件。 映像文件(.img):包含整个文件系统映像,通常用于嵌入式设备和操作系统镜像(Linux、Android)。 Intel HEX文件(.hex):一种文本格式的固件文件,常用于微控制器和嵌入式系统。 Motorola S-record文件(.srec, .s19):类似于Intel HEX格式的文本固件文件。 ELF文件(.elf):一种可执行和可链接格式,包含可执行代码和数据段,常用于嵌入式系统开发。 如下所示,服务商会提供多种格式固件,方便客户进行分析

在这里插入图片描述
在这里插入图片描述

案例

tp-link路由器升级包

固件下载链接 解压后目录结构如下,当前我们关注的还是bin文件

在这里插入图片描述
在这里插入图片描述
怎么解包分析?

这里以.bin格式的固件为例,因为没有明显的文件边界和结构,所以分析起来难度也相对要高些,这里我们使用binwalk来提取和解析内容

binwalk安装及使用
代码语言:javascript
复制
sudo apt-get install binwalk 	// ubuntu
brew install binwalk			// macos
代码语言:javascript
复制
# 识别包含的文件和数据结构
binwalk firmware.bin
在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
# 递归提取内容
binwalk -Me firmware.bin
在这里插入图片描述
在这里插入图片描述

将二进制里面的ubi格式文件提取出来之后

什么是ubi格式文件? UBI(Unsorted Block Image)是一种用于 NAND 闪存的文件系统,它提供了对闪存的磨损均衡和坏块管理。UBI 文件系统常见于嵌入式设备中,尤其是在需

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-07-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 什么是OTA?
  • 升级包(固件)的类型和架构
  • 案例
    • tp-link路由器升级包
      • 怎么解包分析?
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档