首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用于使用其他版本libc的LD_preload在pwntools中不起作用

用于使用其他版本libc的LD_preload在pwntools中不起作用
EN

Stack Overflow用户
提问于 2019-01-29 08:43:33
回答 1查看 5.4K关注 0票数 4

我希望在pwntools中使用其他版本的库来学习pwn,但是出现了EOF错误。

我试图解决这个问题,3次修改了ubuntu版本(18.04桌面-> 14.04桌面-> 18.04.0服务器),4次重新安装python和pwntools。目前版本为ubuntu18.04.0服务器,Python2.7.15rc1,pwntools 3.12.2。

我尝试在pwntools中使用其他版本库来学习pwn。就像这样:

代码语言:javascript
复制
    p = process("./binary_name",env={"LD_PRELOAD" : "./libc_name"})

也试过了

代码语言:javascript
复制
    env = {"LD_PRELOAD": os.path.join(os.getcwd(), "libc_name")}
    p = process("./binary_name",env=env)

并导出python代码,错误发生了,我已经将libc的允许子设置为chmod 777,但是结果是一样的。

代码语言:javascript
复制
    [*] Process './aeiou' stopped with exit code -4 (SIGILL) (pid 77469)
    Traceback (most recent call last):
    File "ex4.py", line 6, in <module>
    p.sendlineafter(">>","3")
    File "/home/synod2/.local/lib/python2.7/site- packages/pwnlib/tubes/tube.py", line 747, in sendlineafter
    ~~~~~~~~~~~~~~
    EOFError

我不知道为什么会发生EOF错误。但是,由于3种不同版本的ubuntu给出了相同的错误,我想我错过了安装。但我不知道我错过了什么!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-03-26 08:56:08

也许你应该在Ubuntu 16上试试。

显然,二进制文件是动态链接的。因此,当程序需要调用某些libc函数时,例如read。它将一些信息传递给动态链接器,然后链接器将计算读取函数的真实地址。

但是libc中的函数有一个version属性。因此,如果您尝试在Ubuntu18.04上使用LD_PRELOAD。动态链接器会尝试在你的2.23版本-libc中找到像read_2_27这样的东西,它只有read_2_23。这样你的程序就不能执行了。

更新:

另一种解决方案是告诉可执行文件使用正确版本的ld.so。

elf文件有一个段(INTERP),其中保存要使用的ld.so路径。您只需将其更改为要使用的ld.so路径即可。

顺便说一句,您可以在ld.so中找到许多版本的存储库

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54416940

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档