首先,SAE的python web框架使用的文档在这里:
使用的tornado版本是3.1。文档里也有提到,Torando的Worker还不稳定,需要谨慎使用。
问题:
首先申明:懒人,只是在本地测试的时候发现这个问题了,线上测试没有进行过,估计也会有。
在使用过程中,发现其他各个方面都还好,但是如果使用Tornado的sattic_path
配置,在本地测试过程中,总会出现static path 中的文件无法访问的问题,浏览器报错误 403, forbiden了,说是权限问题。
原因
文档中有提到
如果config.yaml中没有设置静态文件相关的handlers,系统会默认将/static为前缀 的URL转发到应用目录下的static目录。
所以估计是因为SAE自动的会将 /static 目录作为静态文件目录,然后tornado也会处理这个目录,冲突了。
解决方案
没有在线上进行过测试,但本地可以简单修改tornado的web.py代码解决掉这个问题。
测试发现,其实出错的主要原因,在于web.py会将 /static/yourfile.css
分割开,分成了root部分./static
和path部分yourfile.css
。但是如果加上sae,后面一半path会变成 /yourfile.css
。
解决:在tornado的web.py中,修改函数get_absolute_path
,改成:
def get_absolute_path(cls, root, path): if path.startswith("/"): path = path[1:] # !! 添加这句 abspath = os.path.abspath(os.path.join(root, path)) return abspath
但毕竟没办法修改SAE预装打代码,也就是在本地能用着,所以:
- 很简单,放弃使用tornado的模板引擎,改用其他的模板引擎,如jinja2, pytenjin 什么的,一堆一堆的。
- 哈哈,不用worker喽,老老实实用wsgi。