Entiti HTML Tidak Terhindar dalam JavaScript: Panduan Komprehensif
Apabila bekerja dengan rentetan yang diperoleh daripada XML-RPC atau pelayan lain yang menggunakan entiti HTML melarikan diri , tugas untuk memaparkan rentetan ini dengan betul dalam kandungan HTML boleh menimbulkan cabaran. Berikut ialah beberapa cerapan dan penyelesaian:
Elakkan Kaedah Tidak Boleh Dipercayai
Walaupun pelbagai teknik untuk tidak melarikan diri HTML dalam JavaScript wujud, banyak daripadanya menunjukkan kelemahan yang ketara. Menggunakan kaedah yang gagal mengesahkan rentetan input boleh memperkenalkan eksploitasi Skrip Merentas Tapak (XSS).
Gunakan DOMParser for Safe Unescaping
Untuk memastikan keserasian dan keselamatan, ia amat disyorkan untuk memanfaatkan DOMParser untuk HTML unescaping. Kaedah ini disokong secara asli dalam semua penyemak imbas moden:
function htmlDecode(input) { var doc = new DOMParser().parseFromString(input, "text/html"); return doc.documentElement.textContent; } console.log(htmlDecode("<img src='myimage.jpg'>")); // "<img src='myimage.jpg'>" console.log(htmlDecode("<img src='dummy' onerror='alert(/xss/)'>")); // ""
Dalam contoh ini, anda boleh melihat bahawa teg imej unescaped dipaparkan sebagai imej sebenar, manakala teg hasad dinetralkan dengan berkesan. Ini kerana DOMParser menganggap rentetan input sebagai XML, mentafsir dan menapis kod hasad dengan betul.
Petua Diagnostik
Menyelesaikan masalah yang tidak dapat dielakkan boleh dipermudahkan dengan langkah berikut:
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menyahlepaskan Entiti HTML dengan Selamat dalam JavaScript untuk Mencegah Serangan XSS?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!