我正在尝试使用http-parser
并根据示例here将响应写入文件。这就是我想要做的,我更改了GET请求以请求图像,然后尝试将其保存到文件中:
open('image.jpg', 'wb').write(p.body_file().read())
但该文件的字节数为零。我在这里缺少什么?
完整代码:
#!/usr/bin/env python
import socket
from http_parser.http import HttpStream
from http_parser.reader import SocketReader
def main():
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
try:
s.connect(('www.linux-mag.com', 80))
s.send("GET http://www.linux-mag.com/s/i/topics/tux.jpg HTTP/1.1\r\nHost: www.linux-mag.com\r\n\r\n")
r = SocketReader(s)
p = HttpStream(r)
print p.body_file()
open('image.jpg', 'wb').write(p.body_file().read())
finally:
s.close()
if __name__ == "__main__":
main()
答案 0 :(得分:0)
事实证明我需要sudo
脚本。我做了sudo python <script>
它工作正常。