PHP+Mysql防止SQL注入的方法
发布时间:2020-05-25 08:24:13 所属栏目:PHP 来源:互联网
导读:这篇文章介绍的内容是关于PHP+Mysql防止SQL注入的方法,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 方法一: mysql_real_escape_string -- 转义 S
|
这篇文章介绍的内容是关于PHP+Mysql防止SQL注入的方法,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 方法一: mysql_real_escape_string -- 转义 SQL 语句中使用的字符串中的特殊字符,并考虑到连接的当前字符集 ! $sql = "select count(*) as ctr from users where username ='".mysql_real_escape_string($username)."' and password='". mysql_real_escape_string($pw)."' limit 1"; 方法二: 打开magic_quotes_gpc来防止SQL注入。php.ini中有一个设置:magic_quotes_gpc = Off这个默认是关闭的,如果它打开后将自动把用户提交对sql的查询进行转换,比如把 ' 转为 '等,对于防止sql注射有重大作用。 如果magic_quotes_gpc=Off,则使用addslashes()函数。 方法三: 自定义函数 /**
* 防止sql注入自定义方法一
* author: xiaochuan
* @param: mixed $value 参数值
*/
function check_param($value=null) {
# select|insert|update|delete|'|/*|*|../|./|union|into|load_file|outfile
$str = 'select|insert|and|or|update|delete|'|/*|*|../|./|union|into|load_file|outfile';
if(!$value) {
exit('没有参数!');
}elseif(eregi($str,$value)) {
exit('参数非法!');
}
return true;
}
/**
* 防止sql注入自定义方法二
* author: xiaochuan
* @param: mixed $value 参数值
*/
function str_check( $value ) {
if(!get_magic_quotes_gpc()) {
// 进行过滤
$value = addslashes($value);
}
$value = str_replace("_","_",$value);
$value = str_replace("%","%",$value);
return $value;
}
/**
* 防止sql注入自定义方法三
* author: xiaochuan
* @param: mixed $value 参数值
*/
function post_check($value) {
if(!get_magic_quotes_gpc()) {
// 进行过滤
$value = addslashes($value);
}
$value = str_replace("_",$value);
$value = nl2br($value);
$value = htmlspecialchars($value);
return $value;
}
以上就是PHP+Mysql防止SQL注入的方法的详细内容 更多PHP相关知识请关注我的专栏PHPzhuanlan.zhihu.com (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
