首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >pwntools的p32函数很奇怪

pwntools的p32函数很奇怪
EN

Stack Overflow用户
提问于 2021-02-17 15:38:13
回答 1查看 1.9K关注 0票数 0

我正在测试英特尔x86_64、Ubuntu 64位、Python3、Pwntools v4.3.1

代码语言:javascript
复制
$ python
Python 3.7.4 (default, Aug 13 2019, 20:35:49) 
[GCC 7.3.0] :: Anaconda, Inc. on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from pwn import *
>>> addr = 0xbffffb78
>>> print(p32(addr))
b'x\xfb\xff\xbf'

在我看来,0xbffffb78的正确打包结果应该是\x78\xfb\xff\xbf

但是为什么会发生b'x\xfb\xff\xbf‘呢?\x78在哪里?

正确的打包方式是什么,而不是使用p32()

EN

回答 1

Stack Overflow用户

发布于 2021-02-17 17:06:30

这就是Python呈现bytes objects的方式。如果字节可以呈现为ASCII字符,则它将显示为一个字节。

代码语言:javascript
复制
>>> b"\x78"
b'x'

要查看以十六进制呈现的字节,可以使用bytes对象的hex method

代码语言:javascript
复制
>>> b'x\xfb\xff\xbf'.hex()
'78fbffbf'
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66237553

复制
相关文章

相似问题

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