Почему я вижу ZgotmplZ в моем выходе шаблона Go HTML?
когда я вызываю функцию шаблона Go для вывода HTML, он отображает ZgotmplZ
.
пример кода:
http://play.golang.org/p/tfuJa_pFkm
package main
import (
"html/template"
"os"
)
func main() {
funcMap := template.FuncMap{
"printSelected": func(s string) string {
if s == "test" {
return `selected="selected"`
}
return ""
},
"safe": func(s string) template.HTML {
return template.HTML(s)
},
}
template.Must(template.New("Template").Funcs(funcMap).Parse(`
<option {{ printSelected "test" }} {{ printSelected "test" | safe }} >test</option>
`)).Execute(os.Stdout, nil)
}
выход:
<option ZgotmplZ ZgotmplZ >test</option>
5 ответов
"ZgotmplZ" - это специальное значение, указывающее, что небезопасное содержимое достигло Контекст CSS или URL во время выполнения. Результатом примера будет:
<img src="#ZgotmplZ">
вы можете добавить функцию safe и attr в шаблон funcMap:
пакет main
import (
"html/template"
"os"
)
func main() {
funcMap := template.FuncMap{
"attr":func(s string) template.HTMLAttr{
return template.HTMLAttr(s)
},
"safe": func(s string) template.HTML {
return template.HTML(s)
},
}
template.Must(template.New("Template").Funcs(funcMap).Parse(`
<option {{ .attr |attr }} >test</option>
{{.html|safe}}
`)).Execute(os.Stdout, map[string]string{"attr":`selected="selected"`,"html":`<option selected="selected">option</option>`})
}
вывод будет выглядеть так:
<option selected="selected" >test</option>
<option selected="selected">option</option>
вы можете определить некоторые другие функции, которые могут преобразовать строку в шаблон.CSS шаблон.JS, шаблон.JSStr, шаблон.URL-адрес и т. д.
у меня была аналогичная проблема с <img src="{{myfunction}}">
где myfunction в консоли вернуть закодированные изображения.
наконец, я решил это, когда вместо Строковой функции return template.URL(mystring)
.
вы пытаетесь вывести HTML в месте, где template / html считает небезопасным (например, внутри HTML-элемента, например:
<option {{ printSelected }}>
Я не могу найти способ убедить его, что это безопасно (включая возврат шаблона.HTML вместо строки); единственная альтернатива, которую я нашел, - переписать шаблон, в этом примере вместо этого используйте вывод bool:
<option {{ if printSelected }}selected{{ end }}>
вы должны обернуть строку в HTMLAttr
, который был разработан для текста, который вводится между угловыми скобками. Согласно документации:
https://golang.org/pkg/html/template/#HTMLAttr
HTMLAttr инкапсулирует атрибут HTML из надежного источника, например,
dir="ltr"
.использование этого типа представляет угрозу безопасности: инкапсулированный контент должен поступать из надежного источника, так как он будет включен дословно в выходных данных шаблона.
type HTMLAttr string