Я хочу знать, есть ли лучший способ обработать файл index.html с помощью Tornado.
Я использую StaticFileHandler для всего запроса и использую специальный MainHandler для обработки моего основного запроса. Если я использую только StaticFileHandler, я получил ошибку 403: Forbidden
GET http://localhost:9000/
WARNING:root:403 GET / (127.0.0.1): is not a file
вот как я сейчас делаю:
import os
import tornado.ioloop
import tornado.web
from tornado import web
__author__ = 'gvincent'
root = os.path.dirname(__file__)
port = 9999
class MainHandler(tornado.web.RequestHandler):
def get(self):
try:
with open(os.path.join(root, 'index.html')) as f:
self.write(f.read())
except IOError as e:
self.write("404: Not Found")
application = tornado.web.Application([
(r"/", MainHandler),
(r"/(.*)", web.StaticFileHandler, dict(path=root)),
])
if __name__ == '__main__':
application.listen(port)
tornado.ioloop.IOLoop.instance().start()