1.基础知识:[1](https://www.cnblogs.com/Magpie/p/9948560.html)
[2.](https://blog.youkuaiyun.com/qq_18661257/article/details/54694748)
[3.](https://blog.youkuaiyun.com/zhy025907/article/details/86088368)
2.在程序第一次执行的时,plt表中保存的是对应函数在got表中的位置,got表中保存的是plt表中保存的是一个指向plt表的指针,在该指针中,保存的是一个解析函数,他用来将函数的地址解析出来,然后保存到got表中。在函数执行一次以后,got表中就是函数的真实地址。
这里保存的是got表中的对应位置。

我们去查看一下这个地址里保存的内容。我们拿里面的内容去IDA中查看。

我们发现又回到了plt表中。其实plt表就是一段指令。
有时候我们需要对本次运行的程序进行gdb调试,因为在ASLR的机制下,不同的运行会有所不同。但在gdb中程序的加载地址始终不变,因为gdb默认将pie关掉了。
方法一:
先打开一个终端运行程序,不要输入任何东西,让他挂在那里,然后用ps -a来查看相应的进程,然后用gdb attach 进程前面的数字,来进行gdb表示。

下面介绍两种找进程的方法:



效果如下:

本文介绍了plt表和got表在程序动态链接中的作用,详细阐述了它们如何在程序运行初期解析函数地址。plt表包含指向got表的指针,got表则在解析函数地址后存储真实地址。通过gdb调试,文章展示了如何在ASLR环境下找到并附加到进程,提供两种查找进程的方法,并展示了实际效果。
280

被折叠的 条评论
为什么被折叠?



