在Jinja2中使用DOT渲染字符串时的奇怪行为

时间:2016-06-22 05:50:19

标签: python templates jinja2

这是我的代码:

file = 'http://www.example.com/cdn/.eJwdyjsKksjdbf-sjhdfb-kajsfbnksj'

link = '%s/cdn/%s' % (self.base_url, file)
app.log.debug('link is: %s' % link)
return template.render(link_text=link_text, link=link)

此处日志的输出如下:

2016-06-22 05:37:23,268 - app:log - DEBUG - 330 - 106622  - Thread-6 - link is: http://www.example.com/cdn/.eJwdyjsKksjdbf-sjhdfb-kajsfbnkshdbhj

但链接部分的template.render输出为:

<div height=\\"40px\\" style=\\"width: 189px; height: 43px; line-height: 40px; background-color: #5c9eef; border-radius: 4px; text-align: center;\\">\\n                 
    <a href=\\"http://www.example.com/cdn/\\" style=\\"text-decoration: none; font-weight: 300; line-height: 42px; font-family: tahoma; font-size: 15px;   
    letter-spacing: 1px; color: #fff;\\">Download File</a>\\n

生成的链接缺少.的部分!这是否意味着jinja2在这个角色上表现得很奇怪?!有什么办法可以解决这个问题吗?

1 个答案:

答案 0 :(得分:1)

你需要将你的HTML标记为安全,否则Jinja会执行自动转换。这很简单:

from jinja import Markup

...
return template.render(link_text=link_text, link=Markup(link))

另一种方法是从html模板本身 - 只需将变量标记为安全:

{{ my_variable | safe }}