如何通过Python的BaseHTTPRequestHandler类接收文件?

时间:2014-10-27 23:56:33

标签: python basehttprequesthandler

新手问题了。 BaseHTTPRequestHandler和接收数据......

我一直在使用BaseHTTPRequestHandler来接收作为数据传递给我的URI的JSON字符串。我现在需要接收JSON字符串和ascii文件。我怎么知道我已收到JSON数据和单独的平面文件?如何访问文件中的数据?

如果我收到了多个文件怎么办?

顺便说一句,我刚从Postman&中调用我的URI进行测试。请参阅以下标题:

headers: Host: localhost:6081

Content-Type: application/x-www-form-urlencoded

User-Agent: python-requests/2.2.1 CPython/3.4.0 Linux/3.13.0-35-generic

Accept: */*

Accept-Encoding: gzip, deflate, compress

Content-Length: 403

谢谢!

1 个答案:

答案 0 :(得分:1)

答案在CGI库中。请参阅以下StackOverflow帖子:Simple Python WebServer。该帖子中的第二个答案对我们最有用。

以下是一些测试代码,您可能会发现这些代码可用于打印幕后发生的事情,尤其是当您尝试在一个帖子中接收多个文件时:

        print("command: " + self.command + "\npath: " + self.path + "\nrequest_version: " \
            + self.request_version + "\nheaders: " + str(self.headers))
        form = cgi.FieldStorage(
            fp=self.rfile,
            headers=self.headers,
            environ={'REQUEST_METHOD': 'POST',
                     'CONTENT_TYPE': self.headers['Content-Type'],
                     })
        print("\nform:", str(form))
        print("\nform['file'].filename:", form['file'].filename)
        filename = form['file'].filename
        data = form['file'].file.read()
        open("/tmp/%s" % filename, "wb").write(data)
        print('\ndata:', data)