Maison >développement back-end >Golang >Pourquoi html/template échappe-t-il à \'<\' mais pas à \'>\' ?
" ? " />" ? " />
Comprendre l'échappement HTML/Template
Un problème a été soulevé concernant l'échappement html/template inutilement de "<" vers "<" en quittant "> ;" intact. Pour comprendre ce comportement, examinons d'abord le but de l'échappement HTML/template.
Échappage HTML pour des raisons de sécurité
HTML/template permet un échappement automatique des éléments potentiellement caractères dangereux pour empêcher les vulnérabilités d'injection de code. Cet échappement est sensible au contexte, garantissant que les données sont correctement codées lorsqu'elles sont intégrées dans différents contextes, tels que HTML, CSS ou URI.
html/template pour HTML. Sortie uniquement
Cependant, il est crucial de noter que html/template est spécifiquement conçu pour générer une sortie HTML. Son intention principale est de fournir un moyen sûr d'intégrer les données fournies par l'utilisateur dans des documents HTML.
Utiliser texte/modèle pour une sortie non HTML
Si la sortie dont vous avez besoin n'est pas HTML, vous devez plutôt utiliser texte/modèle. Contrairement à html/modèle, texte/modèle. n'effectue pas d'échappement, vous permettant de générer du texte brut ou des formats de fichiers personnalisés.Conclusion
Dans l'exemple fourni, le modèle est destiné à générer un fichier non HTML fichier, tel qu'un fichier Lisez-moi ou une licence. Par conséquent, vous devez utiliser un texte/modèle, qui ne laisse pas de caractères d'échappement, pour éviter un codage inutile de "<". En choisissant le package de modèles approprié en fonction du format de sortie, vous pouvez garantir le comportement correct et éviter les problèmes d'échappement inattendus.Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!