• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

php简单实现sql防注入的方法_PHP

php 搞代码 3年前 (2022-01-26) 14次浏览 已收录 0个评论

本文实例讲述了php简单实现sql防注入的方法。分享给大家供大家参考,具体如下:

这里没有太多的过滤,主要是针对php和mysql的组合。

一般性的防注入,只要使用php的 addslashes 函数就可以了。

以下是一段copy来的代码:

PHP代码:

$_POST = sql_injection($_POST);$_GET = sql_injection($_GET);function sql_injection($content){if (!get_magic_quotes_gpc()) {if (is_array($content)) {foreach ($content as $key=>$value) {$content[$key] = addslashes($value);}} else {addslashes($content);}}return $content;}

做系统的话,可以用下面的代码,也是copy来的。

PHP代码:

function inject_check($sql_str) { return eregi('select|insert|update|delete|\'|\/\*|\*|\.\.\/|\.\/|union|into|load_file|outfile', $sql_str);  // 进行过滤}function verify_id($id=null) { if (!$id) { exit('没有提交参数!'); }  // 是否为空判断 elseif (inject_check($id)) { exit('提交的参数非法!'); }  // 注射判断 elseif (!is_numeric($id)) { exit('提交的参数非法!'); }  // 数字判断 $id = intval($id);  // 整型化 return $id;}function str_check( $str ) { if (!get_magic_quotes_gpc()) {  // 判断magic_quotes_gpc是否打开  $str = addslashes($str);  // 进行过滤 } $str = str_replace("_", "\_", $str);  // 把 '_'过滤掉 $str = str_replace("%", "\%", $str);  // 把 '%'过滤掉 return $str;}function post_check($post) { if (!get_magic_quotes_gpc()) {  // 判断magic_quotes_gpc是否为打开  $post = addslashes($post);  // 进行magic_quotes_gpc没有打开的情况对提交数据的过滤 } $post = str_replace("_", "\_", $post);  // 把 '_'过滤掉 $post = str_replace("%", "\%", $post);  // 把 '%'过滤掉 $post = nl2br($post);  // <strong>*本文来@源gao@daima#com搞(%代@#码@网2</strong><pre>搞代gaodaima码

回车转换 $post = htmlspecialchars($post); // html标记转换 return $post;}

希望本文所述对大家PHP程序设计有所帮助。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:php简单实现sql防注入的方法_PHP

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址