无法将BufferedReader保存到文件中

时间:2012-09-06 22:26:40

标签: python http

我正在尝试使用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()

1 个答案:

答案 0 :(得分:0)

事实证明我需要sudo脚本。我做了sudo python <script>它工作正常。