Go 템플릿을 사용하여 HTML을 렌더링할 때 출력에 "ZgotmplZ"가 당황스럽게 나타날 수 있습니다. 이 모호한 값은 런타임 시 CSS 또는 URL과 같은 특정 컨텍스트에 도달하는 안전하지 않은 콘텐츠를 감지하는 안전 조치에서 비롯됩니다.
다음 예를 고려하세요.
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>
"ZgotmplZ"가 있으면 안전하지 않은 콘텐츠 selected="selected"가 CSS 컨텍스트. 이러한 시나리오를 처리하려면 템플릿 함수 맵에 "safe" 및 "attr" 기능을 추가할 수 있습니다.
funcMap := template.FuncMap{ "attr": func(s string) template.HTMLAttr { return template.HTMLAttr(s) }, "safe": func(s string) template.HTML { return template.HTML(s) }, }
이러한 기능을 사용하면 다음과 같이 템플릿을 수정할 수 있습니다.
<option {{.attr | attr}}>test</option> {{.html | safe}}
이 수정을 통해 출력은 다음과 같습니다.
<option selected="selected">test</option> <option selected="selected">option</option>
이 솔루션은 안전하지 않은 콘텐츠가 출력. 보안을 강화하고 코드 구성을 유지하기 위해 문자열을 template.CSS, template.JS, template.URL과 같은 다른 유형으로 변환하는 사용자 정의 함수를 정의하는 것을 고려할 수도 있습니다.
위 내용은 My Go 템플릿 출력에 'ZgotmplZ'가 나타나는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!