- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
尽管许多来源引用带有 ENT_QUOTES
的 htmlspecialchars
函数不足以防止 SQL 注入(inject),但它们都没有提供证明概念。我自己想不出任何可能性。
让我们考虑以下示例:
$username = htmlspecialchars($_GET['name'], ENT_QUOTES, 'UTF-8');
$sql = "SELECT * from user WHERE name='$username'";
mysql_query($sql,...);
除了SQL injection gets around mysql_real_escape_string() 的情况之外,任何人都可以提供一个例子吗? ?
最佳答案
htmlspecialchars
未能对关键字符\0
(NUL 字节)、\b
(退格)进行编码的字符,以及\
字符。
为了利用它,您需要一个包含多个注入(inject)点的语句。有了这个,您可以转义一个字符串文字的结束定界符,从而将其扩展到下一个字符串文字的下一个起始定界符。然后可以将每个带有注入(inject)点的三个字符串文字转换为两个字符串文字。
例如:
SELECT * from user WHERE (name='$login' OR email='$login') AND password='$password'
现在具有以下值:
login: ) OR 1=1 /*\
password: */--
结果语句如下所示:
SELECT * from user WHERE (name=') OR 1=1 /*\' OR email=') OR 1=1 /*\') AND password='*/--'
相当于:
SELECT * from user WHERE (name=') OR 1=1 /*\' OR email=') OR 1=1
关于php - htmlspecialchars 是否足以防止对用单引号引起来的变量进行 SQL 注入(inject)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22116934/
我正在尝试执行 vagrant up 但一直遇到此错误: ==> default: IOError: [Errno 13] Permission denied: '/usr/local/lib/pyt
我在容器 div 中有一系列动态创建的不同高度的 div。 Varying text... Varying text... Varying text... Varying text.
通过 cygwin 运行 vagrant up 时遇到以下错误。 stderr: /bin/bash: /home/vagrant/.ansible/tmp/ansible-tmp-14872260
今天要向小伙伴们介绍的是一个能够快速地把数据制作成可视化、交互页面的 Python 框架:Streamlit,分分钟让你的数据动起来! 犹记得我在做机器学习和数据分析方面的毕设时,
我是 vagrant 的新手,正在尝试将第二个磁盘添加到我正在用 vagrant 制作的虚拟机中。 我想出了如何在第一次启动虚拟机时连接磁盘,但是当我关闭机器时 然后再次备份(使用 'vagrant
我是一名优秀的程序员,十分优秀!