Rumah >pembangunan bahagian belakang >Golang >Bagaimana untuk Membuat Baris Baharu dengan Betul dalam Templat HTML?

Bagaimana untuk Membuat Baris Baharu dengan Betul dalam Templat HTML?

Susan Sarandon
Susan Sarandonasal
2024-10-30 20:02:02745semak imbas

How to Render Newlines Correctly in HTML Templates?

Mengatasi Isu Melarikan Diri dalam html/templat dengan Baris Baharu

Dalam templat HTML, baris baharu yang dikodkan sebagai n dipaparkan sebagai entiti HTML (< br>) dan bukannya pemisah baris sebenar. Ini berlaku apabila n aksara dilarikan oleh templat dan bukannya diterima sebagai sebahagian daripada data yang dipercayai.

Penyelesaian: Sanitasi dan Pra-Escaping

Untuk menyelesaikan isu ini, ikut langkah berikut:

  1. Sanitasi teks: Gunakan templat.HTMLEscape() untuk mengalih keluar sebarang aksara yang mungkin berbahaya daripada fail teks.
  2. Ganti baris baharu: Selepas pembersihan, gantikan semua kejadian "n" dengan "
    ".
  3. Gunakan data pra-melarikan diri: Hantar teks yang telah dibersihkan dan digantikan kepada templat sebagai templat.HTML, yang merangkum serpihan HTML yang selamat.

Contoh Pelaksanaan:

Kod berikut menunjukkan proses:

<code class="go">package main

import (
    "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))
}</code>

Kod ini membersihkan teks, menggantikan baris baharu dengan
dan menyerahkannya kepada templat sebagai data pra-melarikan diri. Keputusan yang diberikan akan memaparkan pemisah baris dengan betul seperti yang dimaksudkan tanpa melepaskan isu.

Atas ialah kandungan terperinci Bagaimana untuk Membuat Baris Baharu dengan Betul dalam Templat HTML?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn