Python webapp2路由失败

Python webapp2路由失败,python,google-app-engine,webapp2,Python,Google App Engine,Webapp2,我希望webapp2路由将是容易的,但显然不是(对我来说) 这是一个类似的问题,因为代码几乎相同,但当我使用webapp2.Route时,我只会收到404个错误,当我使用laze routing(正如上面提到的另一个问题中的解决方案)时,我会收到以下丰富多彩的错误消息: ERROR 2011-12-12 17:09:25,996 wsgi.py:186] Traceback (most recent call last): File "/home/user/sdk/google_app

我希望webapp2路由将是容易的,但显然不是(对我来说)

这是一个类似的问题,因为代码几乎相同,但当我使用webapp2.Route时,我只会收到404个错误,当我使用laze routing(正如上面提到的另一个问题中的解决方案)时,我会收到以下丰富多彩的错误消息:

ERROR    2011-12-12 17:09:25,996 wsgi.py:186]
Traceback (most recent call last):
  File "/home/user/sdk/google_appengine/google/appengine/runtime/wsgi.py", line 174, in Handle
    result = handler(self._environ, self._StartResponse)
  File "/home/user/sdk/google_appengine/lib/webapp2/webapp2.py", line 1519, in __call__
    response = self._internal_error(e)
  File "/home/user/sdk/google_appengine/lib/webapp2/webapp2.py", line 1511, in __call__
    rv = self.handle_exception(request, response, e)
  File "/home/user/sdk/google_appengine/lib/webapp2/webapp2.py", line 1505, in __call__
    rv = self.router.dispatch(request, response)
  File "/home/user/sdk/google_appengine/lib/webapp2/webapp2.py", line 1253, in default_dispatcher
    return route.handler_adapter(request, response)
  File "/home/user/sdk/google_appengine/lib/webapp2/webapp2.py", line 1076, in __call__
    handler = self.handler(request, response)
TypeError: __init__() takes exactly 1 argument (3 given)
INFO     2011-12-12 17:09:26,061 dev_appserver.py:2753] "GET / HTTP/1.1" 500 -
INFO     2011-12-12 17:09:26,606 dev_appserver.py:2753] "GET /favicon.ico HTTP/1.1" 200 -
如果我可以使用webapp2.Route,那就太好了,因为它带来了额外的功能(例如命名)。然而,这两种方法似乎对我都不起作用。简而言之,我的代码是这样的:

app.yaml

application: test-app
version: 1
runtime: python27
api_version: 1
threadsafe: true

handlers:
- url: /favicon\.ico
  static_files: static/images/favicon.ico
  upload: static/images/favicon\.ico

- url: .*
  script: main.site_app
  login: required

libraries:
- name: django
  version: "1.2"
main.py

import os
os.environ['DJANGO_SETTINGS_MODULE'] = 'settings'

import webapp2
import urls

site_app = webapp2.WSGIApplication(urls.SITE_URLS, debug=True)
url.py(带webapp2.Route)

url.py(使用webapp2延迟路由)

handler.py

import os
import webapp2
from google.appengine.ext.webapp import template

class TestHome(webapp2.RequestHandler):

  def get(self):
    self.response.write(template.render(
        os.path.join(os.path.dirname(__file__), 'templates/browse.html'), {}
      )
    )


class TestPage(webapp2.RequestHandler):

  def get(self, test_key):
    self.response.write(template.render(
        os.path.join(os.path.dirname(__file__), 'templates/browse.html'),
        {'test_key': test_key}
      )
    )
模板/browse.html

<html>
<head>
  <title>Success!</title>
</head>
<body>
Success!
{% if test_key %}- {{ test_key }}{% endif %}
</body>
</html>

成功!
成功!
{%if test_key%}-{{test_key}{%endif%}

我做错了什么?非常感谢您的帮助/建议!!谢谢

下面是捕获URL的正确正则表达式

SITE_URLS = [
    webapp2.Route(r'/', handler.TestHome),
    webapp2.Route(r'/test/<:\w+>', handler.TestPage)
]
关于这个回溯,我这边没有,但是我使用了GAE prod env(据我所知,您在开发人员上),所以请尝试将webapp2更新到最新版本,并确保在app.yaml中定义的相同py版本上运行代码


嗯。

谢谢!这解决了我的问题。关于回溯,这对我来说是一个愚蠢的错误,因为我在basehandler的init中缺少了*args和**kwargs。谢谢你的帮助!
<html>
<head>
  <title>Success!</title>
</head>
<body>
Success!
{% if test_key %}- {{ test_key }}{% endif %}
</body>
</html>
SITE_URLS = [
    webapp2.Route(r'/', handler.TestHome),
    webapp2.Route(r'/test/<:\w+>', handler.TestPage)
]
 webapp2.Route(r'/test/<your_route_name_here:\w+>', handler.TestPage)
webapp2.Route(r'/test/<category:\w+>/<user_id>/<day:\d+>', handler.TestPage)
class TestPage(webapp2.RequestHandler):
    def get(self, category, user_id, day):
        ...