一、ELF文件格式概述

1. ELF文件

  • ELF:Executable and Linking Format,是一种对象文件的格式,用于定义不同类型的对象文件(Object files)中都放了什么东西、以及都以什么样的格式去放这些东西。

2. 三种类型

(1)可重定位文件

  • 编译器和汇编器创建
  • 运行前需要被链接器处理

(2)可执行文件

  • 完成了所有重定位工作和符号解析
  • 除了运行时解析的共享库符号

(3)共享库文件

  • 链接器需要的符号信息
  • 运行时可以直接执行的代码

二、分析一个ELF文件

  • 以一个最简单的helloworld程序为例

1. ELF文件头

  • 使用工具查看ELF文件头:

      readelf -h obj

  • /usr/include/elf.h 中可以找到文件头结构定义:

  • 大小总共为64字节,换算成十六进制为0x40。在十六进制代码中找到前0x40字节,即为文件头信息部分(阅读时注意反序问题):

(1)identification

  • 魔数部分:

  • 第一部分:占四个字节。

    • 7f 45 4c 46,应读为 4c 46 45 7f,对应ASCII码 ELF.,表示这是一个ELF对象。
  • 第二部分:占一个字节。

    • 02 表示是一个64位对象。
  • 第三部分:占一个字节。

    • 01 表示是小端表示法。
  • 第四部分:占一个字节。

    • 01 表示文件头版本。
  • 其余默认为0

(2)information

  • 信息部分:

  • e_type:两个字节

    • 01 00 表示是一个重定位文件。
  • e_machine:两个字节

    • 3e 00 表示是intel80386处理器体系结构。
  • e_version:四个字节

    • 01 00 00 00 表示是当前版本。
  • e_entry:八个字节。

    • 00 00 00 00 00 00 00 00 表示当前程序没有入口点。
  • e_phoff:八个字节

    • 00 00 00 00 00 00 00 00 表示没有程序头表。
  • e_shoff:八个字节

    • 90 02 00 00 00 00 00 00 表示段表的偏移地址在 00 00 00 00 00 00 02 90处。
  • e_flags:四个字节

    • 00 00 00 00 表示未知处理器特定标志 #define EF_SH_UNKNOWN 0x0
  • e_ehsize:两个字节

    • 40 00 表示elf文件头大小为 00 40(64个字节)。
  • e_phentsize:两个字节

    • 00 00 表示重定位文件没有程序头表。
  • e_phnum:两个字节

    • 00 00 表示重定位文件没有程序头表。
  • e_ehentsize:两个字节

    • 40 00 表示段头大小为00 40(64字节),section header table中每个header的大小。
  • e_shnum:两个字节

    • 0d 00 表示段表入口有13个,即段表有13段。
  • e_shstrndx:两个字节

    • 0a 00 表示段表字符串在段表中的索引号,.shstrab段的段表索引号为00 0a,即10.

2. 通过文件头找到各个节

  • 使用工具查看段表信息

      readelf -S obj

(1)找到段表

  • 在文件头中 e_shoff可以找到段表偏移地址00 00 00 00 00 00 02 90,从这个地址去查找段表。

  • 段表长度由 e_ehentsize00 40(64字节)。

  • 段表个数由 e_shnum 可知有13个。

  • /usr/include/elf.h 中可以找到段表结构:

(2)分析一个段表

  • 第一个段:全为零,不表示任何段。

  • 第二个段:

  • sh_name:四个字节

    • 20 00 00 00 表示该段名称在.shstrtab中偏移量,为.test节。
  • sh_type:四个字节

    • 01 00 00 00 表示这个段拥有程序所定义的信息,其格式和含义完全由该程序确定,这里表示PROGBITS。
  • sh_flags:八个字节

    • 06 00 00 00 00 00 00 00 表示alloc和execute。
  • sh_addr:八个字节

    • 00 00 00 00 00 00 00 00 表示是section在内存中的虚拟地址,.o文件不需要执行,这里都是0。
  • sh_offset:八个字节

    • 40 00 00 00 00 00 00 00 表示是section与文件头之间的偏移。
  • sh_size:八个字节

    • 11 00 00 00 00 00 00 00 表示文件里面section占用的大小。
  • sh_link:四个字节

    • 00 00 00 00 表示没有链接信息。
  • sh_info:四个字节

    • 00 00 00 00 表示没有辅助信息。
  • sh_addralign:八个字节

    • 01 00 00 00 00 00 00 00 表示字节对齐长度。
  • sh_entsize:八个字节

    • 00 00 00 00 00 00 00 00 表示没有入口。

(3)所有段表

  • 第三个段:

    • 段名:.rel.text
    • 类型:RELA
    • 标志:info
    • 相对文件头偏移:0x1e0
    • 占用大小:0x30
  • 第四个段

    • 段名:.data
    • 类型:PROGBITS
    • 标志:write、alloc
    • 相对文件头偏移:0x51
    • 占用大小:0
  • 第五个段

    • 段名:.bss
    • 类型:NOBITS
    • 标志:write、alloc
    • 相对文件头偏移:0x51
    • 占用大小:0
  • 第六个段

    • 段名:.rodata
    • 类型:PROGBITS
    • 标志:alloc
    • 相对文件头偏移:0x51
    • 占用大小:0x0b
  • 第七个段

    • 段名:.comment
    • 类型:PROGBITS
    • 标志:merge、strings
    • 相对文件头偏移:0x5c
    • 占用大小:0x26
  • 第八个段

    • 段名:.note.GNU-stack
    • 类型:PROGBITS
    • 标志:无
    • 相对文件头偏移:0x82
    • 占用大小:0
  • 第九个段

    • 段名:.eh_frame
    • 类型:PROGBITS
    • 标志:alloc
    • 相对文件头偏移:0x88
    • 占用大小:0x38
  • 第十个段

    • 段名:.rela.eh_frame
    • 类型:RELA
    • 标志:info
    • 相对文件头偏移:0x210
    • 占用大小:0x18
  • 第十一段

    • 段名:.shstrtab
    • 类型:STRTAB
    • 标志:无
    • 相对文件头偏移:0x228
    • 占用大小:0x61
  • 第十二段

    • 段名:.symtab
    • 类型:STRTAB
    • 标志:无
    • 相对文件头偏移:0xc0
    • 占用大小:0x0108
  • 第十三段

    • 段名:.strtab
    • 类型:STRTAB
    • 标志:无
    • 相对文件头偏移:0x1c8
    • 占用大小:0x11

三、理解常见节

1. .text节

本节中是可执行指令的集合
  • 通过刚才的信息,我们可以从文件中偏移0x40处找到大小为0x11的 .text节:

  • 可以通过反汇编该程序来查看:

2. .rodata

本节是只读数据,ro代表read only
  • 从偏移0x51处找到大小为0x0b的 .rodata节:

  • 使用ASCII码对照表翻译数据为hello 5317,即.c文件中的字符串:

2. .comment

本节用来存放编译器版本信息
  • 从偏移0x5c处找到大小为0x26的 .comment节:

  • 使用ASCII码对照表翻译出来数据为 GCC:(Debian 5.3.1-8) 5.3.1 20160205

3. .symtab

本节存放所有section中定义的符号名字,一般是变量、函数shstrtab及symtab经常引用strtab中的字符串
  • 从偏移0xc0处找到大小为0x0108的 .symtab节:

4. .strtab

本节是段表的字符串表
  • 从偏移0x1c8处找到大小为0x11的 .strtab节:

  • 数据用“0”分隔出了三部分,用ASCII码翻译:

    • 65 6c 66 2e 63elf.c
    • 6d 61 69 6emain
    • 70 75 74 73puts

Linux课程实践四:ELF文件格式分析的更多相关文章

  1. Linux课题实践四——ELF文件格式分析

    2.4   ELF文件格式分析 20135318 刘浩晨 ELF全称Executable and Linkable Format,可执行连接格式,ELF格式的文件用于存储Linux程序.ELF文件(目 ...

  2. Linux及安全实践四——ELF文件格式分析

    Linux及安全实践四——ELF文件格式分析 一.ELF文件格式概述 1. ELF:是一种对象文件的格式,用于定义不同类型的对象文件中都放了什么东西.以及都以什么样的格式去放这些东西. 二.分析一个E ...

  3. 20135218 实践四 ELF文件格式分析

    一 :概述 ELF全称Executable and Linkable Format,可执行连接格式,ELF格式的文件用于存储Linux程序.ELF文件(目标文件)格式主要三种: (1)可重定向文件:文 ...

  4. linux第三次实践:ELF文件格式分析

    linux第三次实践:ELF文件格式分析 标签(空格分隔): 20135328陈都 一.概述 1.ELF全称Executable and Linkable Format,可执行连接格式,ELF格式的文 ...

  5. Linux实践:ELF文件格式分析

    标签(空格分隔): 20135321余佳源 一.基础知识 ELF全称Executable and Linkable Format,可执行连接格式,ELF格式的文件用于存储Linux程序.ELF文件(目 ...

  6. 20135337——linux实践三:ELF文件格式分析(32位系统)

    ELF文件格式分析 可重定位文件 十六进制形式显示内容 显示各个段.符号表相关信息 查看各个段信息 elf文件头信息 段表 符号表信息 查看堆栈 具体分析 1.ELF文件头信息(小字节优先,均十六进制 ...

  7. 实践2.4 ELF文件格式分析

    实践2.4 ELF文件格式分析 1.ELF文件头 查看/usr/include/elf.h文件: #define EI_NIDENT (16) typedef struct { unsigned ch ...

  8. linux实践之ELF文件分析

    linux实践之ELF文件分析 下面开始elf文件的分析. 我们首先编写一个简单的C代码. 编译链接生成可执行文件. 首先,查看scn15elf.o文件的详细信息. 以16进制形式查看scn15elf ...

  9. 20135306 2.4 ELF文件格式分析

    2.4   ELF文件格式分析 20135306 黄韧 ELF全称Executable and Linkable Format,可执行连接格式,ELF格式的文件用于存储Linux程序.ELF文件(目标 ...

随机推荐

  1. 利用SQL 建立和删除 LINKED SERVER

    USE IS21_xxx; if object_id('tempdb..#tmp') is not null drop table #tmp create table #tmp ( cntr ), i ...

  2. CreateIoCompletionPort() 函数

    /* ********************* * CreateIoCompletionPort() 函数有两个功能: * 1.创建一个完成端口: * 2.将一个设备与一个存在的完成端口进行绑定,在 ...

  3. java 验证手机号码、电话号码(包括最新的电信、联通和移动号码)

    一.目前的号码段(2016-12-8更新)   二.代码 package com.test; import java.util.regex.Pattern; public class CheckPho ...

  4. xcode 工具学习笔记

    1. 快速打开辅助界面   快捷键:使用Option + 单击文件   2. 辅助编辑器更多打开方式   快捷键: Option+shift +单击文件   3. tab页面快捷键   快捷键: Co ...

  5. 【HEVC】2、HM-16.7编码一个CU(帧内部分) 1.帧内预测相邻参考像素获取

    HEVC帧内预测的35中预测模式是在PU基础上定义的,实际帧内预测的过程则以TU为单位.PU以四叉树划分TU,一个PU内所有TU共享同一种预测模式.帧内预测分3个步骤: (1) 判断当前TU相邻像素点 ...

  6. 好用的一个从SharePoint导出小工具

      1. 输入 Site Url(Site Collection), 然后点"load"按钮 2.选择Web后,点选需导出的文档库,然后点"Next"按钮   ...

  7. KMS服务器激活Windows和Office2013EnterprisePlus

    KMS服务器激活Windows和Office2013EnterprisePlus 参考了文档 http://wenku.baidu.com/view/0cb2602358fb770bf68a5501. ...

  8. 几种常见 容器 比较和分析 hashmap, map, vector, list ...hash table

    list支持快速的插入和删除,但是查找费时; vector支持快速的查找,但是插入费时. map查找的时间复杂度是对数的,这几乎是最快的,hash也是对数的.  如果我自己写,我也会用二叉检索树,它在 ...

  9. 二叉树遍历(Binary Tree Traversal)

    二叉树的递归遍历比较简单,这里说一下非递归遍历,以中序遍历为例子. 非递归遍历主要用到栈来协助进行.对于一个二叉树,首先根节点入栈,如果有左儿子,则继续入栈,重复直到最左边的儿子,这时候此节点值为要遍 ...

  10. 常用linux维护命令

    cat /etc/issue  查看linux版本信息