(MYSQL学习笔记5)防止SQL注入

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了(MYSQL学习笔记5)防止SQL注入相关的知识,希望对你有一定的参考价值。

mysql服务器并不存在共享池(我也不清楚共享池是什么)的概念,所以在MYSQL上使用绑定变量最大的好处就是为了防止SQL注入。


php例子:

$stmt = $dbh -> prepare("SELECT * FROM users WHERE username=? AND password=?");

$stmt -> execute(array($username,$password));

即使传入的变量中,带有"angel ‘ or 1=1‘"的条件,但是由于绑定变量,使得输入的参数中的单引号被正常转义,导致后续的"or 1=1"作为username的条件出现,而不是整个SQL语句的条件,即"angel \‘ or 1=1\‘"。


本文出自 “w1sw” 博客,请务必保留此出处http://cfdeng.blog.51cto.com/9873532/1948769

以上是关于(MYSQL学习笔记5)防止SQL注入的主要内容,如果未能解决你的问题,请参考以下文章

python之MySQL学习——防止SQL注入(参数化处理)

sql注入学习笔记4

ClickHouse-尚硅谷(5. 入门-SQL 操作)学习笔记

MySQL如何防止SQL注入

sql注入学习笔记2

5月11日 python学习总结 子查询pymysql模块增删改查防止sql注入问题