readelf使用说明

本文介绍readelf命令,该命令用于显示ELF格式文件的各种信息,包括文件头、程序头、节头等。readelf适用于32位和64位ELF文件及静态库文件,其功能比objdump更具体,并且不依赖BFD库。

简介

readelf命令用来显示一个或者多个elf格式的目标文件的信息,可以通过它的选项来控制显示哪些信息。这里的elf-file(s)就表示那些被检查的文件。可以支持32位,64位的elf格式文件,也支持包含elf文件的文档(这里一般指的是使用ar命令将一些elf文件打包之后生成的例如lib*.a之类的“静态库”文件)。 

这个程序和objdump提供的功能类似,但是它显示的信息更为具体,并且它不依赖BFD库(BFD库是一个GNU项目,它的目标就是希望通过一种统一的接口来处理不同的目标文件),所以即使BFD库有什么bug存在的话也不会影响到readelf程序。 

运行readelf的时候,除了-v和-H之外,其它的选项必须有一个被指定。 

ELF文件类型

  • 可重定位文件:用户和其他目标文件一起创建可执行文件或者共享目标文件,例如lib*.a文件。 
  • 可执行文件:用于生成进程映像,载入内存执行,例如编译好的可执行文件a.out。 
  • 共享目标文件:用于和其他共享目标文件或者可重定位文件一起生成elf目标文件或者和执行文件一起创建进程映像,例如lib*.so文件。

 

ELF文件作用

ELF文件参与程序的连接(建立一个程序)和程序的执行(运行一个程序),所以可以从不同的角度来看待elf格式的文件: 

  • 如果用于编译和链接(可重定位文件),则编译器和链接器将把elf文件看作是节头表描述的节的集合,程序头表可选。 
  • 如果用于加载执行(可执行文件),则加载器则将把elf文件看作是程序头表描述的段的集合,一个段可能包含多个节,节头表可选。 
  • 如果是共享文件,则两者都含有。 

 

ELF文件总体构成

 

elf文件头描述elf文件的总体信息。包括:系统相关,类型相关,加载相关,链接相关。 

 

  • 系统相关表示:elf文件标识的魔术数,以及硬件和平台等相关信息,增加了elf文件的移植性,使交叉编译成为可能
  • 类型相关就是前面说的那个类型。 
  • 加载相关:包括程序头表相关信息。 
  • 链接相关:节头表相关信息。 

选项

-a
--all 显示全部信息,等价于 -h -l -S -s -r -d -V -A -I.

-h
--file-header 显示elf文件开始的文件头信息.

-l
--program-headers 
--segments 显示程序头(段头)信息(如果有的话)。

-S
--section-headers 
--sections 显示节头信息(如果有的话)。

-g
--section-groups 显示节组信息(如果有的话)。

-t
--section-details 显示节的详细信息(-S的)。

-s
--syms       
--symbols 显示符号表段中的项(如果有的话)。

-e
--headers 显示全部头信息,等价于: -h -l -S

-n
--notes 显示note段(内核注释)的信息。

-r
--relocs 显示可重定位段的信息。

-u
--unwind 显示unwind段信息。当前只支持IA64 ELF的unwind段信息。

-d
--dynamic 显示动态段的信息。

-V
--version-info 显示版本段的信息。

-A
--arch-specific 显示CPU构架信息。

-D
--use-dynamic 使用动态段中的符号表显示符号,而不是使用符号段。

-x<number or name>
--hex-dump=<number or name>以16进制方式显示指定段内内容。number指定段表中段的索引,或字符串指定文件中的段名。

-w[liaprmfFsoR] or
--debug-dump[=line,=info,=abbrev,=pubnames,=aranges,=macro,=frames,=frames-interp,=str,=loc,=Ranges]显示调试段中指定的内容。

-I
--histogram 显示符号的时候,显示bucket list长度的柱状图。

-v
--version 显示readelf的版本信息。

-H
--help 显示readelf所支持的命令行选项。

-W
--wide 宽行输出。

@file可以将选项集中到一个文件中,然后使用这个@file选项载入。

 

 

 

 

 

 


<think>好的,用户想了解如何使用readelf -p命令,需要示例、语法和解释。首先,我得回忆一下readelf的基本知识。根据引用[5],readelf是用来显示ELF文件信息的工具,而-p参数用于以字符串形式转储特定节的内容。用户可能已经知道readelf的基本用途,但需要具体了解-p的用法。 我需要先确认语法结构。引用[5]提到-p的参数格式是--string-dump=<number|name>,所以命令应该是readelf -p <节名或编号> <文件>。需要解释参数的含义,比如节名可以是.rodata、.comment等,编号是节头表中的索引。 接下来要提供示例,比如查看.comment节的字符串内容,或者用编号来指定节。还要注意是否需要其他参数,比如-W来避免截断输出。用户可能需要知道如何查找节名或编号,这时候可能需要结合-S参数,比如先用readelf -S查看所有节的信息,再确定要转储的节。 还要解释输出结果的含义,比如转储的内容是该节中所有可打印的字符串。需要提醒常见的应用场景,比如查看编译器的版本信息或注释。同时,要确保用户明白该命令在分析ELF文件时的实际用途,比如调试或逆向工程。 另外,用户可能遇到的问题,比如如何知道有哪些节名可用,或者如何处理大段的输出。这时候建议使用管道符结合less查看,或者重定向到文件。还要注意权限问题,可能需要sudo来访问某些文件。 最后,生成相关问题,帮助用户深入理解,比如其他相关参数的使用,或者如何结合其他命令如objdump一起分析ELF文件。确保回答结构清晰,步骤明确,示例实用,让用户能够按照指导自行操作。</think>### readelf -p 命令详解 #### 语法格式 ``` readelf -p <节名或编号> <ELF文件> 或 readelf --string-dump=<节名或编号> <ELF文件> ``` #### 核心功能 用于**以字符串形式转储指定节的内容**,仅显示可打印字符(ASCII值 >= 0x20且 <= 0x7E)[^5]。适用于分析包含字符串的节,例如: - `.comment`(编译器注释) - `.rodata`(只读数据) - `.dynstr`(动态链接字符串表) --- #### 使用示例 1. **查看.comment节内容**(包含编译器版本信息): ```bash readelf -p .comment /usr/bin/ls # 输出示例: String dump of section '.comment': [ 0] GCC: (Ubuntu 9.4.0-1ubuntu1~20.04) 9.4.0 [ 2b] GCC: (Ubuntu 11.4.0-1ubuntu1~22.04) 11.4.0 ``` 2. **使用节编号转储**(需先通过`readelf -S`查看节编号): ```bash readelf -S main | grep .rodata # 假设.rodata是第15节 readelf -p 15 main ``` 3. **避免截断输出**(使用-W参数显示完整内容): ```bash readelf -Wp .dynstr libc.so.6 ``` --- #### 参数说明 | 参数组合 | 作用 | |---------|------| | `-p <name>` | 按节名称转储 | | `-p <number>` | 按节编号转储 | | `-W` | 显示完整宽度内容(默认80字符限制)[^5] | --- #### 技术原理 1. ELF文件通过节头表(Section Header Table)管理数据分区,每个节存储特定类型数据 2. `-p`参数通过解析节头表定位目标节,按字节扫描提取连续可打印字符序列 3. 输出格式为`[偏移量]`+字符串内容,偏移量相对于节起始地址[^2] ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值