栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

html / templates-用替换换行符

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

html / templates-用替换换行符

看来您可以先在文本上运行template.HTMLEscape()进行净化,然后执行 n
替换所信任的内容,然后将其用作预先转义和信任的模板数据。

更新:在Kocka的示例上扩展,这是我想到的:

package mainimport (    "html/template"    "os"    "strings")const page = `<!DOCTYPE html><html>  <head>  </head>  <body>    <p>{{.}}</p>  </body></html>`const text = `first line<script>dangerous</script>last line`func main() {    t := template.Must(template.New("page").Parse(page))    safe := template.HTMLEscapeString(text)    safe = strings.Replace(safe, "n", "<br>", -1)    t.Execute(os.Stdout, template.HTML(safe)) // template.HTML encapsulates a known safe HTML document fragment.}

http://play.golang.org/p/JiH0uD5Zh2

输出为

<!DOCTYPE html><html>  <head>  </head>  <body>    <p>first line<br>&lt;script&gt;dangerous&lt;/script&gt;<br>last line</p>  </body></html>

在浏览器中呈现的文本是

first line<script>dangerous</script>last line


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/436193.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号