0

我正在尝试使用此处http-parser的示例并将响应写入文件。这就是我想要做的,我将 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()
4

1 回答 1

0

事实证明,我需要sudo脚本。我做到sudo python <script>了,效果很好。

于 2012-09-06T22:34:17.867 回答