这个问题可能在另一端。
使用Tornado 2.4.1进行以下测试会得到预期的输出。
import logging
import urllib
from tornado.ioloop import IOLoop
from tornado.web import Application, RequestHandler, asynchronous
from tornado.httpclient import HTTPRequest, AsyncHTTPClient
from tornado import gen, options
log = logging.getLogger()
options.parse_command_line()
class PutBodyTest(RequestHandler):
@asynchronous
@gen.engine
def get(self):
data = {
'text': 'important text',
'timestamp': 'a timestamp'
}
req = HTTPRequest(
'http://localhost:8888/put_body_test',
method='PUT',
body=urllib.urlencode(data)
)
res = yield gen.Task(AsyncHTTPClient().fetch, req)
self.finish()
def put(self):
log.debug(self.request.body)
application = Application([
(r"/put_body_test", PutBodyTest),
])
if __name__ == "__main__":
application.listen(8888)
IOLoop.instance().start()
日志输出:
$ python put_test.py --logging=debug
[D 130322 11:45:24 put_test:30] text=important+text×tamp=a+timestamp
[I 130322 11:45:24 web:1462] 200 PUT /put_body_test (127.0.0.1) 0.37ms
[I 130322 11:45:24 web:1462] 200 GET /put_body_test (::1) 9.76ms
你从哪里导入'HTTPRequest'?而且你怎么实例化客户端' – aychedee 2013-03-21 23:17:39
HTTPRequest来自tornado.httpclient,而客户端是tornado.httpclient.ASyncHTTPClient的别名。我会更新这个问题来说明问题。 – 2013-03-22 02:18:53
我没有看到你在这里的代码有什么问题。可能是处理程序代码中的一个微妙的错误? – aychedee 2013-03-22 07:39:30