>백엔드 개발 >Golang >HTML 템플릿에서 개행 문자를 ``로 안전하게 바꾸는 방법은 무엇입니까?

HTML 템플릿에서 개행 문자를 ``로 안전하게 바꾸는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-01 07:46:02405검색

How to safely replace newlines with `` in HTML templates?

줄바꿈을
로 바꾸기 HTML 템플릿에서

HTML 템플릿에서 줄바꿈을 표시하려면 몇 가지 고려 사항이 필요합니다. 줄 바꿈이 템플릿에 의해
로 이스케이프되어 줄 바꿈 대신 리터럴 HTML 태그로 표시될 수 있기 때문입니다. 이는 개행 문자가 포함된 텍스트 파일을 로드하고 이를 HTML 템플릿에 전달할 때 문제를 야기합니다.

일반적으로 제안되는 솔루션은 개행 문자(n)를
로드된 문자열에서. 그러나 이 접근 방식은 공격자가 의 " 문자를 통해 악성 코드를 주입하여 XSS 보호를 회피할 수 있으므로 보안 취약성을 초래할 수 있습니다.

한 가지 대안은 template.HTMLEscape()를 활용하여 줄 바꿈을
로 대체하기 전에 텍스트를 삭제하세요. 이 방법은 잠재적으로 위험한 문자를 피하여 템플릿 데이터의 안전을 보장합니다.

다음은 이 기술을 보여주는 예입니다.

<code class="go">import (
    "html/template"
    "os"
    "strings"
)

const page = `<!DOCTYPE html>\n<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))
}</code>

실행 시 출력은 다음과 같습니다.

<code class="html"><!DOCTYPE html>
<html>
  <head>
  </head>
  <body>
    <p>first line<br><script>dangerous</script><br>last line</p>
  </body>
</html></code>

요약하자면, 정리된 텍스트를 HTML 템플릿에 전달하면 줄 바꿈을 올바르게 표시하는 동시에 XSS 취약점을 효과적으로 방지할 수 있습니다.

위 내용은 HTML 템플릿에서 개행 문자를 ``로 안전하게 바꾸는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.