如何解决pwntools 的 p32 函数很奇怪
我正在英特尔 x86_64、Ubuntu 64 位、python3、Pwntools v4.3.1 上进行测试
$ 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()
的正确打包方式是什么?
解决方法
这就是 Python 呈现 bytes objects 的方式。如果一个字节可以呈现为 ASCII 字符,则显示为一个。
>>> b"\x78"
b'x'
要查看呈现为十六进制的字节,您可以使用字节对象的 hex method:
>>> b'x\xfb\xff\xbf'.hex()
'78fbffbf'
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。