pwn小白入门 装载 笔记
阿里云国内75折 回扣 微信号:monov8 |
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6 |
所看视频奉上
笔记如下
1.查看文件类型
file 文件名
其中
add文件名
ELF文件格式
64-bit64位
LSB端序 lsb小端序 msb:大端序
x86-64:架构
dynamically动态链接
interpreter 解释器
内核GNU/Linux 3.2.0
HASH:BuildID[sha1]=ede5b2f24049ad7513cadff0224a885d0d58ccbe
not stripped调试信息没有被剥夺掉
2.链接
链接就是将目标文件链接成一个可执行文件。
- 静态链接
链接的时间是运行之前。
每个目标文件的静态库都会被载入内存。从而增加了内存的数量。
最简单的方法是按序叠加。
弊端是链接的文件过多时输出的可执行文件会非常零散。段的装载地址和空间以页为单位不足一页的也会占用一页这样会造成内存空间的浪费。
另一种方式是相似节合并。讲不同的目标文件相同的属性合并成一个节。这种被当前的连接器采用。
- 动态链接
动态链接是链接的时间是在程序运行或加载的时候
在内存中完成链接的过程。
动态链接只载入目标文件所调用的库被共享。
这些用于动态链接的系统库称为共享库或者共享对象
整个过程由动态链接器完成。
GCC默认由动态链接编译。
2.2位置无关代码
可以加载而无需冲定位的代码称为位置无关代码。他是共享库必须具有的属性。
2.3延时绑定
延时绑定当函数第一次被调用的时候动态链接器才会进行符号查找、重定位等操作如果没有被调用就不绑定。
由于动态链接是由动态链接器在程序加载的时候进行的当需要时定位的符号函数库多了之后势必会影响性能。延时绑定就是为了解决这一,问题。