php - 规避用于 HTML/JavaScript 注入(inject)的 htmlspecialchars(addslashes(input))

标签 php html htmlspecialchars addslashes

假设一些 PHP 代码回显通过首先将 addslashes() 然后 htmlspecialchars() 应用到 HTML 文档而净化的输入。我听说这是一种不安全的方法,但不知道为什么。

对于可以将哪种格式应用于危险输入(例如脚本标记中的 JavaScript)以绕过这两个函数强加的安全措施的任何建议,我们将不胜感激。

最佳答案

addslashes与 XSS 无关(并且在实际有用的地方几乎总是有更好的东西)。

htmlspecialchars不是不安全的方法。它本身是不够的。

htmlspecialchars如果您将内容作为“安全”元素的主体,将会保护您。

如果您将内容作为“安全”属性的值并正确引用该值,它将保护您。

如果您将它作为“不安全”属性或元素(其中内容可能被视为 JavaScript)的值,例如 <script>,它不会保护您。 , onmoseover , hrefstyle .


例如:

<!-- http://example.com/my.php?message=", steal_your_cookies(), " -->
<!-- URL not encoded for clarity. Imagine the definition of steel_your_cookies was there too -->

<button onclick='alert("<?php echo htmlspecialchars($_GET['message']); ?>")'>
   click me
</button>

会给你:

<button onclick='alert("&quot;, steal_your_cookies(), &quot;")'>
   click me
</button>

这意味着:

<button onclick='alert("", steal_your_cookies(), "")'>
   click me
</button>

当您点击按钮时,它会窃取您的 cookie。

关于php - 规避用于 HTML/JavaScript 注入(inject)的 htmlspecialchars(addslashes(input)),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27249888/

相关文章:

html - 如何创建第一列固定且下一列可水平滚动的 HTML 表格

html - 带有文本的 Bootstrap 行故障

Twig - 使用引号作为连接过滤器的分隔符

javascript - 我如何使用 PHP 对包含引号的字符串进行编码以使其对于内联 'onclick' 是安全的?

php - 添加的 ID/类别在更新时删除

php - Laravel 登录(Auth::attempt)不工作

php - 使用从数据库中选择的不同数据发送组邮件

php - 管理员身份验证的 img 未加载到 Laravel 8 中

php - 使用 HTML 表单更新多个 MySQL 表