最近弃用 FILTER_SANITIZE_STRING 和 FILTER_SANITIZE_STRIPPED 常量引起了依赖它们进行输入的 PHP 开发人员的担忧
不推荐使用什么以及为什么?
FILTER_SANITIZE_STRING 和 FILTER_SANITIZE_STRIPPED 以前用于从输入字符串中删除潜在的 XSS 漏洞。然而,这些过滤器表现出令人困惑和不直观的行为。 FILTER_SANITIZE_STRING 删除了“<”之间的所有字符以及字符串的末尾,删除了 NUL 字节,并对单引号和双引号进行了编码。
PHP 社区确定这些过滤器造成的混乱比它们解决的问题还要多,因为开发人员经常误解它们的预期用途。其他过滤器(例如 FILTER_UNSAFE_RAW)已充分处理输入清理。
替换选项
有多种选项可以替换这些已弃用的内容filters:
function filter_string_polyfill(string $string): string { $str = preg_replace('/\x00|<[^>]*>?/', '', $string); return str_replace(["'", '"'], [''', '"'], $str); }记住黄金法则
重要的是要强调输入清理不应被视为针对 XSS 攻击的可靠防御。相反,开发人员应该专注于转义输出,以防止潜在危险的内容被注入到页面中。
以上是PHP 的 FILTER_SANITIZE_STRING 弃用:最佳替代选项是什么?的详细内容。更多信息请关注PHP中文网其他相关文章!