0

我刚刚在我的烧瓶项目中添加了烧瓶安全性。它在本地工作,但在 OpenShift 上报告此错误:

TemplateAssertionError: no filter named 'urlencode'

我不知道这是否是一些错误的库版本,或者如何调试它。这是我的 setup.py 包列表:

install_requires=['Flask==0.10.1',
                    'SQLAlchemy==0.9.8',
                    'Flask-SQLAlchemy==2.0',
                    'Flask-Security==1.7.4',
                    'Werkzeug==0.9.5',
                    'blinker==1.3',
                    'Flask-Login==0.2.11',
                    'Flask-Mail==0.9.1',
                    'Flask-Principal==0.4.0',
                    'Flask-Script==2.0.5',
                    'Flask-WTF==0.10.3',
                    'itsdangerous==0.24',
                    'passlib==1.6.2'

  ]
4

2 回答 2

1

v2.7中添加了urlencode过滤器。但 GAE只支持 v2.6。在我仍然使用 2.6 运行时将版本更改为“最新” (注意路径):jinjaapp.yamlpython27_lib/versions/third_party/jinja2-2.6/jinja2/environment.py

...
 File "/base/data/home/apps/s~healthier-staging/1.386037228785871893/lib/flask/templating.py", line 128, in render_template
context, ctx.app)
  File "/base/data/home/apps/s~healthier-staging/1.386037228785871893/lib/flask/templating.py", line 110, in _render
    rv = template.render(context)
  File "/base/data/home/runtimes/python27/python27_lib/versions/third_party/jinja2-2.6/jinja2/environment.py", line 894, in render
return self.environment.handle_exception(exc_info, True)
  File "/base/data/home/apps/s~healthier-staging/1.386037228785871893/lib/flask_security/templates/security/_menu.html", line 4, in template
<li><a href="{{ url_for_security('login') }}{% if 'next' in request.args %}?next={{ request.args.next|urlencode }}{% endif %}">Login</a></li>
TemplateAssertionError: no filter named 'urlencode'`

我通过手动添加一个简单的过滤器(复制添加到 jinja 的代码)来解决这个问题:

def do_urlescape(value):
    """Escape for use in URLs."""
    return urllib.quote(value.encode('utf8'))
app.jinja_env.globals['urlencode'] = do_urlescape
于 2015-07-28T17:01:49.370 回答
0

我已经解决了这个问题,方法是在我的本地机器上执行“pip freeze”,并将库一个一个复制到 setup.py。虽然我仍然不确定哪个产生了错误,可能是 jinja2 的错误版本。

于 2015-01-23T00:58:05.717 回答