- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在学习如何避免 SQL 注入(inject),但我有点困惑。
使用bind_param时,我不明白其用途。在手册页上,我找到了这个示例:
$stmt = mysqli_prepare($link, "INSERT INTO CountryLanguage VALUES (?, ?, ?, ?)");
mysqli_stmt_bind_param($stmt, 'sssd', $code, $language, $official, $percent);
$code = 'DEU';
$language = 'Bavarian';
$official = "F";
$percent = 11.2;
现在,假设这 4 个变量是用户输入的,我不明白这如何防止 SQL 注入(inject)。据我了解,他们仍然可以在那里输入任何他们想要的内容。
我也找不到其中 'sssd'
的解释。它有什么作用?这就是它更安全的原因吗?
最后一个问题:我在另一个问题上读到 mysqli_real_escape_string
已弃用,但手册中没有这么说。它是如何被弃用的?由于某种原因它不能再转义特殊字符吗?
注意:这个问题解释了bind_param的作用,但我仍然不明白为什么它更安全或更 protected 。 Bind_param explanation
最佳答案
Now, assuming those 4 variables were user-inputted, I don't understand how this prevents SQL injections. By my understanding, they can still input whatever they want in there.
主要原理是使用预准备语句,该语句旨在向数据库服务器发送安全查询,这可以通过转义不属于实际查询一部分的用户输入来完成,并且还可以在没有任何(where子句)的情况下检查查询在使用任何参数之前检查查询的有效性。
来自这个问题:PDO sends raw query to MySQL while Mysqli sends prepared query, both produce the same result
$stmt = $mysqli->prepare("SELECT * FROM users WHERE username =?")) {
$stmt->bind_param("i", $user);
$user = "''1''";
服务器日志:
130802 23:39:39 175 Connect ****@localhost on testdb
175 Prepare SELECT * FROM users WHERE username =?
175 Execute SELECT * FROM users WHERE username =0
175 Quit
通过使用准备好的语句,数据库服务器将检查不带任何参数的查询,在这个阶段,可以在绑定(bind)任何参数之前检测到错误,然后,如果查询有效,参数也会发送到服务器以最终确定查询。
摘自 PHP 手册 http://php.net/manual/en/mysqli.quickstart.prepared-statements.php :
Escaping and SQL injection
Bound variables will be escaped automatically by the server. The server inserts their escaped values at the appropriate places into the statement template before execution. A hint must be provided to the server for the type of bound variable, to create an appropriate conversion. See the mysqli_stmt_bind_param() function for more information.
..
I also can't find an explanation for the 'sssd' in there. What does it do? Is that what makes it secure-er?
答案在这里:http://php.net/manual/en/mysqli-stmt.bind-param.php
i
corresponding variable has type integer
d
corresponding variable has type double
s
corresponding variable has type string
b
corresponding variable is a blob and will be sent in packets
Final question: I read on another question that mysqli_real_escape_string is deprecated, but it doesn't say that in the manual. How is it deprecated? Can it not escape special characters anymore for some reason?
能给个引用吗?我认为您误解了 (mysql_real_escape_string()
)
关于php - bind_param 的作用是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18426172/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!