linux的逆向基础
data:image/s3,"s3://crabby-images/c0fa6/c0fa6d238ca8b5589323940c60eb0c2284d1dcf1" alt=""
1.ELF格式
我们先来看看 ELF 文件头,如果想详细了解,可以查看ELF的man page文档。
data:image/s3,"s3://crabby-images/e4066/e40667986e417a0cec9c2f3bb5679f86578eecfa" alt=""
关于ELF更详细的说明:e_shoff:节头表的文件偏移量(字节)。如果文件没有节头表,则此成员值为零。sh_offset:表示了该section(节)离开文件头部位置的距离
data:image/s3,"s3://crabby-images/9f8bc/9f8bcb8c6aad433eb9d4b73e45ed6ea564eedb85" alt=""
2.可执行头部(Executable Header)
ELF文件的第一部分是可执行文件头部(Executable Header),其中包含有关ELF文件类型的信息。ELF文件在各种平台下都通用,ELF文件有32位版本和64位版本,其文件头内容是一样的,只不过有些成员的大小不一样。它的文件图也有两种版本:分别叫“Elf32_Ehdr”和“Elf64_Ehdr”。这里以32位版本为例:
data:image/s3,"s3://crabby-images/fe173/fe173e142b83a8fb3eecc354d57dc86ce53d6ce0" alt=""
使用readelf对ELF文件格式进行分析
data:image/s3,"s3://crabby-images/d926a/d926a6a5530ecf82f69d8874eacbf68358eed80c" alt=""
我们可以使用以下计算方法来计算整个二进制文件的大小:
size = e_shoff + (e_shnum * e_shentsize)size = Start of section headers + (Number of section headers * Size of section headers)size = 137000 + (29*64) = 138856计算结果验证:
data:image/s3,"s3://crabby-images/05e60/05e60229707e92de977395b157b5b0bb76e4cbb2" alt=""
3、程序头部(Program Headers)
程序头部是描述文件中的各种segments(段),用来告诉系统如何创建进程映像的。
data:image/s3,"s3://crabby-images/0205d/0205dad5b9e790cdd1c052e4419533e04a6d3687" alt=""
4、节表头部(Section Headers)
节表头部(Section Headers)包含了描述文件节区的信息,比如大小、偏移等,但这些对二进制文件的执行流程来说并不重要。
- sections 或者 segments:segments是从运行的角度来描述elf文件,sections是从链接的角度来描述elf文件,也就是说,在链接阶段,我们可以忽略program header table来处理此文件,在运行阶段可以忽略section header table来处理此程序(所以很多加固手段删除了section header table)。从图中我们也可以看出, segments与sections是包含的关系,一个segment包含若干个section。
data:image/s3,"s3://crabby-images/d33e0/d33e0b034303ae973a36cbdb01eb32a182f1bc09" alt=""
data:image/s3,"s3://crabby-images/f606c/f606c9060ed6ab399b6d63718e47d14447745d15" alt=""
- 5、表(Section)
- 5.1 .bss Section
- 保存未初始化的数据,比如那些未初始化的全局变量。
- 5.2 .data Section
- 保存已初始化的数据。
- 5.3 .rodata Section
- 保存程序中的只读数据。
- 5.4 .text Section
- 本节包含程序的实际代码,逻辑流程。使用readelf查看ELF文件表结构
data:image/s3,"s3://crabby-images/188a4/188a410cb6a14adaaf6f2edfa20475c77b500587" alt=""
data:image/s3,"s3://crabby-images/cec3a/cec3a85b8fdc8c75d4e32e570920a10a82bfc0e4" alt=""
- 6、完成简单的CTF挑战
- 既然已经对ELF文件有所了解了,那找一个CTF题目来试试吧。
- 二进制文件下载地址:https://ufile.io/blvpm
- 国内下载:www.lanzous.com/i34qg6f
- 1、运行这个程序,并传递一些随机字符给它,得到的结果如下:
data:image/s3,"s3://crabby-images/4f84c/4f84cc6aee2e98d51d0daaadb0344b66cf217082" alt=""
- 2、接着使用strings 查看一下程序的字符串,看是否能找到有用的信息
data:image/s3,"s3://crabby-images/91bea/91bea6fddb9c19e0f1117d6d5ff5e1dc9a456b4e" alt=""
- 我们可以看到 “%c” 是打印flag的字符串,数量是15个。
- 3、我们可以查看“.rodata ”部分的偏移量,可以更好的查看这些字符
data:image/s3,"s3://crabby-images/82a5c/82a5c18e1043ec0072d032ea53fe5a4f9486e376" alt=""
- 4、检查符号表(Symbols)nm命令查看库文件的符号
data:image/s3,"s3://crabby-images/f59bc/f59bc47d93d434af06442a5cc0dca61dfcee5b74" alt=""
- 说明:-D或–dynamic:显示动态符号。该任选项仅对于动态目标(例如特定类型的共享库)有意义我们可以发现 printf, puts, sprintf, strlen functions.这些函数未定义。5、跟踪系统调用(System Calls)我们可以使用strace之类的工具去跟踪程序的系统调用
data:image/s3,"s3://crabby-images/7e86a/7e86a2cb998d81f9b6997a9e68af5a192b5b4699" alt=""
data:image/s3,"s3://crabby-images/68819/68819fc43c967aeaab39aaba390461b6022f40c5" alt=""
- 为了更好地理解,我们可以使用ltrace解码C++来跟踪函数名所做的库调用。我们可以看到正在进行字符串长度检查。
data:image/s3,"s3://crabby-images/3024f/3024f3395e94b64d717e2d8c84547672d07b0f9b" alt=""
- 为了更好地理解,我们可以使用ltrace解码C++来跟踪函数名所做的库调用。我们可以看到正在进行字符串长度检查。
data:image/s3,"s3://crabby-images/3cf17/3cf17337c4e0501de972c0f52476ee9da1d62662" alt=""
data:image/s3,"s3://crabby-images/4f065/4f065bf406d69f557af567b9e6763db770e9046a" alt=""
data:image/s3,"s3://crabby-images/5f555/5f555f07582738dbe1d6a812f1deecbbfbb6bc4a" alt=""
data:image/s3,"s3://crabby-images/8b09e/8b09e0a223545cf927e789d84ea7b8fe39eb5041" alt=""
data:image/s3,"s3://crabby-images/f8485/f8485d854f9fb020d16f5afa4375b07ed943d5a9" alt=""
data:image/s3,"s3://crabby-images/4a528/4a52817589359d623366f0ba0220fb6825585f00" alt=""
data:image/s3,"s3://crabby-images/9cbab/9cbab252e96b9fd83e50baf8fab11134bf4f4eca" alt=""
data:image/s3,"s3://crabby-images/8ec4f/8ec4fdcf722c2d8fce7d96ac23736a7d14036c00" alt=""
data:image/s3,"s3://crabby-images/555d6/555d64380df646be13104bddd2a8c3b599635a89" alt=""
- 在这个二进制文件中,符号没有被剥离,因此我们可以看到函数名称,这使得它更容易理解。如果你可以阅读汇编代码,你可以很清楚的知道发生了什么。如果不能阅读汇编代码,让我们做一些实时调试,并尝试更好地理解。7、实时调试这里我们使用GDB-Peda进行实时调试我们首先检查二进制文件中的函数。我们可以看到main,comp_key等函数
data:image/s3,"s3://crabby-images/1df2a/1df2a96f5d14159104b41add3d813748fa013f51" alt=""
- 调试方法:首先使用 break main 跳到主函数,使用n来step和ni来执行每条指令
data:image/s3,"s3://crabby-images/399b6/399b6cc7c87680a885ed725a2c0ff2bc834b2f99" alt=""
data:image/s3,"s3://crabby-images/20138/20138d0f28599c9274d701a8224c33a173ba8735" alt=""
- 让我们来看看程序的逻辑,程序首先尝试比较参数的数量。它存储在ecx寄存器中并移动到esi,它用于将值与0×2进行比较
data:image/s3,"s3://crabby-images/00aa7/00aa7ee876424edbdfe0c49fbc9710b12cad79de" alt=""
- 其伪代码看起来是这样的:
data:image/s3,"s3://crabby-images/8277d/8277d7272592eb35280132641d17d56eb8b5a48f" alt=""
data:image/s3,"s3://crabby-images/bad35/bad35248ec8707ac90dad60bb88c82225510adb9" alt=""
- 其代码是这样的:
data:image/s3,"s3://crabby-images/b2243/b224376be518933e6d865e0ec697157cce62c183" alt=""
- 如果你检查这个代码,可以看到有一个循环正在迭代我们输入字符串的每个字符。
data:image/s3,"s3://crabby-images/a6ca7/a6ca72b90045b047d613d572d329afb21c62e4aa" alt=""
data:image/s3,"s3://crabby-images/9bd2a/9bd2acee9cf918fd686c3a326bd93c9047b1c991" alt=""
- 它到底循环了多少个字符?通常来说,我们的密码长度为7个字符。
data:image/s3,"s3://crabby-images/a8309/a8309ce76a09f0adb4d0ee6de252a7b74d5fe6a7" alt=""
data:image/s3,"s3://crabby-images/fced1/fced1f04769dc0a391a075f3e29286ad77c6b1cf" alt=""
- 代码看起来是这样的:
data:image/s3,"s3://crabby-images/73f70/73f70715aa8b4eb8d20e598907259a3e23b7cb16" alt=""
- 可以看出,如果7个字符总和等于801,即可得到flag。您可以使用任何字符,只要总和是801即可。检查完成后,调用comp_key函数并打印出flag。比如这样:114 * 6 + 177 = 801我们找到数字对应的ASCII字符114是 ‘r’ 117 是 ‘u’。
data:image/s3,"s3://crabby-images/d0fd2/d0fd2149c17d2979cfea5712e76dba9665d86c19" alt=""
- 然后我们将字符作为输入,执行程序即可得到FLAG
data:image/s3,"s3://crabby-images/91849/91849e300086a4758c09621ef1cb95b0b0de0e86" alt=""
相关推荐
-
第18问:MySQL CPU 高了,怎么办?2025-02-24 10:27:18
-
mysql索引类型 normal, unique, full text
mysql索引类型 normal, unique, full text2025-02-24 10:05:05 -
uwsgi+django+nginx 搭建部分总结2025-02-24 10:03:33
-
使用Docker配置Nginx环境部署Nextcloud2025-02-24 10:02:03
-
Nginx安装和怎么使用2025-02-24 10:00:45