gpt4 book ai didi

php - mysql_real_escape_string 是否足以防止 HTML 注入(inject)?

转载 作者:行者123 更新时间:2023-12-01 00:14:46 26 4
gpt4 key购买 nike

我想知道如何防止 HTML 注入(inject)。我创建了一个站点,允许用户以 HTML 形式粘贴文章。我使用了 mysql_real_escape_sting 但我想知道这是否足以防止 HTML 注入(inject)。我尝试了 htmlspecialchars 但它显示 mysql_real_escape_string 错误。

最佳答案

不, mysql_real_escape_sting 只准备要安全地插入到 MySQL 字符串声明中的数据,以防止在该特定上下文中进行 SQL 注入(inject)。它不会阻止其他注入(inject),例如 HTML 注入(inject)或跨站点脚本 (XSS)。

HTML 注入(inject)和 XSS 都发生在不同的上下文中,需要注意不同的上下文特殊字符。在 HTML 中特别是 < , > , & , " , 和 '分隔不同的 HTML 上下文。考虑到 XSS,您还需要了解不同的 JavaScript 上下文及其特殊字符。

htmlspecialchars 应该足以处理前一次攻击,而 json_encode 可用于 JavaScript 的安全子集。另见 XSS (Cross Site Scripting) Prevention Cheat Sheet以及my answer to Are these two functions overkill for sanitization?和相关问题以获取有关此主题的更多信息。

关于php - mysql_real_escape_string 是否足以防止 HTML 注入(inject)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6883310/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com