应用在本地运行正常但在appspot上不行

2 投票
2 回答
965 浏览
提问于 2025-04-16 15:53

我正在让用户通过Foursquare在我的网页上进行身份验证,当他们被重定向回我的网页时,我会从网址中提取返回的信息。在本地测试时一切正常,但当我部署到线上时,出现了以下错误

    Traceback (most recent call last):
  File "/base/python_runtime/python_lib/versions/1/google/appengine/ext/webapp/__init__.py", line 634, in __call__
    handler.get(*groups)
  File "/base/data/home/apps/hoosheer/4.349803081119561985/hoosheer_main.py", line 34, in get
    foursquareMethods.foursquareDetails(self)
  File "/base/data/home/apps/hoosheer/4.349803081119561985/foursquareMethods.py", line 40, in foursquareDetails
    doRender(self, '500.html')
  File "/base/data/home/apps/hoosheer/4.349803081119561985/foursquareMethods.py", line 67, in doRender
    handler.response.out.write(template.render(path, template_values))
  File "/base/python_runtime/python_lib/versions/1/google/appengine/ext/webapp/template.py", line 72, in render
    t = load(template_path, debug)
  File "/base/python_runtime/python_lib/versions/1/google/appengine/ext/webapp/template.py", line 100, in load
    template = django.template.loader.get_template(file_name)
  File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/template/loader.py", line 80, in get_template
    template = get_template_from_string(source, origin, template_name)
  File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/template/loader.py", line 88, in get_template_from_string
    return Template(source, origin, name)
  File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/template/__init__.py", line 158, in __init__
    self.nodelist = compile_string(template_string, origin)
  File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/template/__init__.py", line 174, in compile_string
    return parser.parse()
  File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/template/__init__.py", line 273, in parse
    compiled_result = compile_func(self, token)
  File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/template/loader_tags.py", line 154, in do_extends
    nodelist = parser.parse()
  File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/template/__init__.py", line 273, in parse
    compiled_result = compile_func(self, token)
  File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/template/loader_tags.py", line 132, in do_block
    nodelist = parser.parse(('endblock', 'endblock %s' % block_name))
  File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/template/__init__.py", line 280, in parse
    self.unclosed_block_tag(parse_until)
  File "/base/python_runtime/python_lib/versions/third_party/django-0.96/django/template/__init__.py", line 318, in unclosed_block_tag
    raise self.error(None, "Unclosed tags: %s " %  ', '.join(parse_until))
TemplateSyntaxError: Unclosed tags: endblock, endblock bodycontent

更新

在我的代码中,似乎导致问题的那一行是我尝试执行 doRender(self, '500.html') 时。这是 doRender 方法

def doRender(handler, tname, values = { }):    
    template_values = dict(values) 
    handler.session = Session()
    if 'access_token' in handler.session: 
        template_values['access_token'] = handler.session['access_token'] 
    path = os.path.join(os.path.dirname(__file__), tname)
    handler.response.out.write(template.render(path, template_values))

而模板如下

{% extends "index.html" %} 
{% block bodycontent %}
Server Error
      <p>
      There has been an error
      </p>
{% endblock %}

2 个回答

0
TemplateSyntaxError: Unclosed tags: endblock, endblock bodycontent
{% endblock %}

这段话告诉你至少有一个问题出现在了哪里。你需要关闭这个 endblock

1

你在你的app.yaml文件里设置了'/_ah/login_required'这个处理程序吗?

我假设你已经开启了联邦登录,这样才能使用Foursquare的账号。如果是这样的话,你需要定义一个自己的登录处理程序,这样它才能在appspot上正常工作(本地测试用localhost的登录处理方式是不同的)。

例如:

handlers:
- url: /_ah/login_required
  script: do_openid_login.py

撰写回答