python - Flask源碼異常處理問題
問題描述
Flask version: 0.3
我事先在views.py里面定義了如下的異常處理方法:
@app.errorhandler(404)def page_not_found(): return 'this page is not found.', 404 @app.errorhandler(500)def page_error(): return 'this page is error.', 500 #:: 這兩個(gè)異常處理方法都是錯(cuò)誤的,因?yàn)闆]有加參數(shù)。
先貼幾段源碼
#:: 片段1def wsgi_app(self, environ, start_response): with self.request_context(environ):try: rv = self.preprocess_request() if rv is None:rv = self.dispatch_request() response = self.make_response(rv) response = self.process_response(response)except Exception, e: response = self.make_response(self.handle_exception(e))return response(environ, start_response)#:: 片段2def dispatch_request(self): req = _request_ctx_stack.top.request try:if req.routing_exception is not None: raise req.routing_exception #:: 拋出異常return self.view_functions[req.endpoint](**req.view_args) except HTTPException, e:return self.handle_http_exception(e)#:: 片段3class _RequestContext(object): def __init__(self, app, environ):self.app = appself.url_adapter = app.url_map.bind_to_environ(environ)self.request = app.request_class(environ)self.session = app.open_session(self.request)if self.session is None: self.session = _NullSession()self.g = _RequestGlobals()self.flashes = Nonetry: self.request.endpoint, self.request.view_args = self.url_adapter.match() #:: 不匹配except HTTPException, e: print e.code, e.description self.request.routing_exception = e #:: 片段4def handle_exception(self, e): handler = self.error_handlers.get(500) if self.debug:raise self.logger.error('hello') self.logger.exception(’Exception on %s [%s]’ % (request.path,request.method )) if handler is None:return InternalServerError() return handler(e) #:: handler不為None,之前定義了500的錯(cuò)誤處理
然后我在瀏覽器輸入了一個(gè)不存在的路由http://localhost:5000/test,想看Flask如何異常處理。
請(qǐng)求過來之后會(huì)先執(zhí)行片段1, 然后代碼走到片段3請(qǐng)求上下文,片段3中self.url_adapter.match()拋出HTTPException異常被捕獲。然后執(zhí)行到片段2,然后拋出異常被片段1捕獲到執(zhí)行片段4,最后會(huì)執(zhí)行到handler(e)這條語(yǔ)句。
我的問題來了,因?yàn)槲叶x的500的錯(cuò)誤處理里面,沒有加參數(shù),導(dǎo)致這條語(yǔ)句執(zhí)行失敗。
報(bào)了如下錯(cuò)誤:
Traceback (most recent call last): File '/Users/virtualenvs/full-stack/lib/python2.7/site-packages/werkzeug/serving.py', line 180, in run_wsgi execute(self.server.app) File '/Users/virtualenvs/full-stack/lib/python2.7/site-packages/werkzeug/serving.py', line 168, in execute application_iter = app(environ, start_response) File '/Users/virtualenvs/full-stack/flask0.3/examples/flaskr/flask.py', line 1435, in __call__ return self.wsgi_app(environ, start_response) File '/Users/virtualenvs/full-stack/lib/python2.7/site-packages/werkzeug/wsgi.py', line 591, in __call__ return self.app(environ, start_response) File '/Users/virtualenvs/full-stack/flask0.3/examples/flaskr/flask.py', line 1382, in wsgi_app response = self.make_response(self.handle_exception(e)) File '/Users/virtualenvs/full-stack/flask0.3/examples/flaskr/flask.py', line 1266, in handle_exception return handler(e)TypeError: page_error() takes no arguments (1 given)
從Traceback當(dāng)中能看出最后也是這句的錯(cuò)誤。然而瀏覽器還是返回了500的頁(yè)面,返回的內(nèi)容是Werkzeug自定義的頁(yè)面內(nèi)容。
Internal Server ErrorThe server encountered an internal error and was unable to complete your request. Either the server is overloaded or there is an error in the application.
既然程序都已經(jīng)執(zhí)行錯(cuò)誤了,那為什么還能夠返回HTTP Response呢?謝謝:-)
問題解答
回答1:報(bào)錯(cuò)信息提示很清楚 File '/Users/virtualenvs/full-stack/flask0.3/examples/flaskr/flask.py', line 1266, in handle_exception
return handler(e)
TypeError: page_error() takes no arguments (1 given)
page_error() 不需要參數(shù),你傳遞了一個(gè)參數(shù)。
相關(guān)文章:
1. javascript - js 有什么優(yōu)雅的辦法實(shí)現(xiàn)在同時(shí)打開的兩個(gè)標(biāo)簽頁(yè)間相互通信?2. html5和Flash對(duì)抗是什么情況?3. javascript - 怎樣限制同一個(gè)瀏覽器不能登錄兩個(gè)賬號(hào)4. java - 新手做一個(gè)安卓視頻播放器,想實(shí)現(xiàn)一個(gè)進(jìn)度條,按鈕那種在視頻下方懸浮的功能,不知道思路!5. css3 - Typecho 后臺(tái)部分表單按鈕在 Chrome 下出現(xiàn)靈異動(dòng)畫問題,求解決6. javascript - angular和jquery都用到了$符號(hào),一起用會(huì)不會(huì)沖突?7. java - android代碼重構(gòu):如何把a(bǔ)pp設(shè)置里的頭像UI做成通用的?8. 想找個(gè)php大神仿個(gè)網(wǎng)站。9. javascript - 一個(gè)抽獎(jiǎng)的效果(如圖)?10. javascript - jquery怎么給select option一個(gè)點(diǎn)擊時(shí)觸發(fā)的事件,如圖 如果選擇自定義觸發(fā)一個(gè)時(shí)間?
