jQuery を使用した HTML 文字列のシームレスなエスケープ
HTML 文字のエスケープは、インジェクション攻撃などのセキュリティの脆弱性を防ぐために重要です。 jQuery はさまざまな操作メソッドを提供しますが、HTML エスケープ専用のネイティブ関数がありません。このニーズに対処するために、jQuery で簡単に実装できる、mustache.js の一般的で効率的なソリューションを検討します。
mustache.js のエスケープ関数
mustache.js ライブラリは、任意の文字列を HTML セーフな値に変換する効果的なscapeHtml 関数を提供します。エンティティ マップを作成して、安全でない文字を対応する HTML 文字参照に置き換えます。この関数を jQuery 内で連鎖させることで、潜在的な脅威を簡単に無力化できます:
jQuery Extension
jQuery.fn.escapeHtml = function() { const entityMap = { '&': '&amp;', '<': '&lt;', '>': '&gt;', '"': '&quot;', "'": '&#39;', '/': '&#x2F;', '`': '&#x60;', '=': '&#x3D;' }; return this.each(function() { $(this).text(String($(this).html()).replace(/[&<>"'`=\/]/g, function (s) { return entityMap[s]; })); }); };
使用例
$('#myElement').escapeHtml();
このスニペットは、#myElement 内の HTML をエスケープされた同等のものに置き換えます。 <、>、& などの文字は、無害な HTML エンティティに変換されます。
以上がjQuery を使用して HTML 文字列を安全にエスケープするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。