5

我决定安装 jinja2 与我的 webapp 应用程序一起使用,以支持自动转义功能。所以我将 jinja2 安装到 python 2.5 中,并在我的项目中创建了一个指向该目录的符号链接。它大部分工作正常。

除了,当我实际尝试使用 {% autoescape true %} 标记时,我收到以下消息:

File "/Users/me/project/templates/_base.html", line 1, in template
    {% autoescape true %}
TemplateSyntaxError: Encountered unknown tag 'autoescape'.

我正在使用文档中的标签:

{% autoescape true %} stuff {{var1}} stuff {{var2}}{% endautoescape %}

在我的处理程序文件中,我正在导入相关的东西:

from jinja2 import Environment, FileSystemLoader, TemplateNotFound
from jinja2.ext import autoescape

并且导入工作正常,因为它没有引发错误。我做错了什么,还是 jinja2 本身有问题,比如在 ext.py 中?


更新:我在下面尝试了 sharth 的建议并得到了相同的结果。这是我使用他的建议更新的处理程序。

class MainHandler(BaseHandler):
    def get(self):

        self.context['testEscape']='<script type="javascript">alert("hi");</script>'
        env = Environment(loader=FileSystemLoader([os.path.join(os.path.dirname(__file__), 'templates')]), autoescape=False)
        template = env.get_template('index.html')
        content = template.render(self.context)
        self.response.out.write(content)

同样,只要我不使用 autoescape 标签,它就可以正常工作。

4

1 回答 1

8

{% autoescape %}标签需要 Jinja 2.4 或更高版本并加载jinja2.ext.autoescape扩展。

env = Environment(autoescape=True, extensions=['jinja2.ext.autoescape'],
                  loader=...)
于 2011-01-13T07:47:31.857 回答