php防止sql注入

三个函数:

addslashes($string):用反斜线引用字符串中的特殊字符\' \" \\

$username=addslashes($username);

mysql_escape_string($string):用反斜杠转义字符串中的特殊字符,用于mysql_query()查询。

$username=mysql_escape_string($username);

mysql_real_escape_string($string):转义SQL语句中使用的字符串中的特殊字符,并考虑到连接的当前字符集,需要保证当前是连接状态才能用该函数,否则会报警告。 不转义%与_

$username=mysql_real_escape_string($username);

两种选择:

使用PDO

$stmt = $pdo->prepare(\'SELECT * FROM user WHERE name = :name\');

$stmt->execute(array(\':name\' => $name));

foreach ($stmt as $row) {

// do something with $row

}

使用mysqli

$stmt = $dbConnection->prepare(\'SELECT * FROM user WHERE name = ?\');

$stmt->bind_param(\'s\', $name);

$stmt->execute();

$result = $stmt->get_result();

while ($row = $result->fetch_assoc()) {

// do something with $row

}

版权声明:
作者:超级管理员
链接: https://blog.apecloud.ltd/article/detail.html?id=37
来源:猿码云个人技术站
文章版权归作者所有,未经允许请勿转载。

THE END
分享
二维码
打赏
/static/admin/img/weixin.jpg/static/admin/img/zfb.jpg
<<上一篇>
go语言基础语法结构总结
下一篇>>