在Tornado Web服务器上下载文件

3

这是我当前定义tornado web服务器的方式:

application = tornado.web.Application([
    tornado.web.url(r"/server", MainHandler),
    tornado.web.url(r"/(.*)", tornado.web.StaticFileHandler, { "path": scriptpath,  "default_filename": "index.html" }),
])

index.html是网页GUI的起始页面。它将通过http:///server与后端服务器通信,GUI对服务器的请求由MainHandler函数处理。

目录结构如下:

root_directory/
    server.py
    fileiwanttodownload.tar.gz
    index.html

我希望能够在浏览器中输入以下内容:

http:///data/fileiwanttodownload.tar.gz

然后将文件作为普通文件下载。

我尝试过的方法是:

application = tornado.web.Application([
    tornado.web.url(r"/server", MainHandler),
    tornado.web.url(r"/data", tornado.web.StaticFileHandler, { "path": scriptpath } ),
    tornado.web.url(r"/(.*)", tornado.web.StaticFileHandler, { "path": scriptpath,  "default_filename": "index.html" }),
])

但是这并没有起作用,对于那些知道答案的人来说,原因可能是显而易见的。

我唯一的线索是以下错误消息:

Uncaught exception GET /data (192.168.4.168)
HTTPServerRequest(protocol='http', host='192.168.4.195:8888', method='GET', uri='/data', version='HTTP/1.1', remote_ip='192.168.4.168', headers={'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_2) AppleWebKit/601.3.9 (KHTML, like Gecko) Version/9.0.2 Safari/601.3.9', 'Host': '192.168.4.195:8888', 'Accept-Encoding': 'gzip, deflate', 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', 'Connection': 'keep-alive', 'Accept-Language': 'en-us'})
Traceback (most recent call last):
  File "/usr/local/lib/python3.4/dist-packages/tornado/web.py", line 1445, in _execute
    result = yield result
  File "/usr/local/lib/python3.4/dist-packages/tornado/gen.py", line 1008, in run
    value = future.result()
  File "/usr/local/lib/python3.4/dist-packages/tornado/concurrent.py", line 232, in result
    raise_exc_info(self._exc_info)
  File "<string>", line 3, in raise_exc_info
  File "/usr/local/lib/python3.4/dist-packages/tornado/gen.py", line 267, in wrapper
    result = func(*args, **kwargs)
TypeError: get() missing 1 required positional argument: 'path'
1个回答

2

scriptpath这个变量你没有展示,可能是错误的。在path中,你应该提供文件的根目录,在URI匹配器中只捕获文件或者类似的东西。以下是一个简单的例子:

import tornado.ioloop
import tornado.web
import os

class MainHandler(tornado.web.RequestHandler):
    def get(self):
        self.write("Hello, world")

def make_app():
    script_path = os.path.dirname(__file__)
    return tornado.web.Application([
        (r"/", MainHandler),
        (r"/data/(.*)", tornado.web.StaticFileHandler, {"path": script_path}),
        #         ^ we capture only this part
    ])

if __name__ == "__main__":
    app = make_app()
    app.listen(8888)
    tornado.ioloop.IOLoop.current().start()

您可以直接运行它,但建议将静态/数据文件存储在单独的目录中,因为可能会从应用程序根目录下载所有内容,包括Python文件。

因此,请将可下载的文件放在data子目录中,然后

script_path = os.path.join(os.path.dirname(__file__), 'data')

关于StaticFileHandler的更多信息。

编辑

你遇到的错误是因为在你的代码中,/data路由有StaticFileHandler,但请求路径中没有任何内容被捕获()


Bingo。解决方案是执行r"/data/(.*)"。 - ericg

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接