Linux之ELF魔数解析
在Linux系统下,我们通常可以使用readelf命令来查看ELF文件信息。例如:
ELF文件有32位版本以及64版本之分,32位版本的结构体信息如下:
上面这些结构跟刚才输出的kill0这个文件的elf信息基本一一对应,不同的是,Elf32_Ehdr中的e_ident对应了readelf输出中的“Class”,"Data","Version","OS/ABI","ABI Version"。
而我们所要说的ELF魔数指的就是第一幅图中画线的数字。
最开始的四个字节是所有ELF文件都必须相同的标识符,分别为0x7F,0x45,0x4c,0x46,第一个字节对应ASCII字符里面的DEL控制符,后面三个字节刚好是ELF这三个字节的ASCII码。这四个字节称为ELF的魔数。几乎所有的可执行文件格式的最开始的几个字节都是魔数。这种魔数用来确认文件的类型,操作系统在加载可执行文件的时候会确认魔数是否正确。
相关推荐
清溪算法 2020-04-23
Joymine 2020-01-03
哥哥的CSDN集 2019-12-22
87530399 2016-12-20
dqcoffee 2016-12-20
zjhqlmzldx 2011-07-07
sffwul 2017-07-07
viplinux 2012-03-24
christinzhm 2012-01-14
卢从利 2011-05-11
cooldatabase 2017-08-28
supetan 2010-05-12
Attend 2014-11-01
dannistang 2013-04-29
德尔菲斯的港湾 2017-03-15
qifei 2012-08-20
if 2010-02-22
nklinux 2007-04-10