学以致用

focus on Python , C++, and some interest in Go and R

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

在使用webpy时发现的web.application reload的猫腻,暂时记录下来,以便自己和他人参考。
现象是这样的:
  在配置文件中定义urls:

urls = (
# front page
"/", "app.controllers.base.index",
"/index/", "app.controllers.base.index",
)

  同时为了隐藏部分url对应关系,在程序中增加url映射关系如下:

self._app.add_mapping(url_login, Login)
self._app.add_mapping(url_logout, Logout)

启动webpy主程序代码如下:
  

app = web.application(urls, globals())
app.run()

系统运行时访问url_login却提示404 Not Found错误,也就是说程序中增加(url_login, Login)的映射并没有真正成功。
通过跟踪分析webpy源码发现,原来webpy为了提高开发环境下的调试效率,特意在构造application时可以指定是否autoreload url配置,如果在创建application时autoreload为None或者web.config.debug 为 True,则在每次处理每一个request时都重新加载mapping,如果autoreload为True,则每次重新构建时mapping都被初始化为创建application时传入的urls。也就是说在程序中增加的mapping都会在处理request时被清除。
为解决这一问题,可以在创建application时将autoreload设置为False或者将web.config.debug设置为False,代码如下

# in development debug error messages and reloader
web.config.debug = False
# in production, we should disable the autoreload of the urls mapping
app = web.application(urls, globals(), autoreload = False)







  

posted on 2012-03-02 16:14  Jerry.Kwan  阅读(1117)  评论(0编辑  收藏  举报