• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 浅谈开启magic_quote_gpc后的sql注入攻击与防范

浅谈开启magic_quote_gpc后的sql注入攻击与防范

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了sql注入攻击,sql注入攻击与防御,sql注入式攻击,如何防止sql注入攻击,sql注入攻击实例等相关知识,希望本文的分享对您有所帮助
通过启用php.ini配置文件中的相关选项,就可以将大部分想利用SQL注入漏洞的骇客拒绝于门外。
开启magic_quote_gpc=on之后,能实现addslshes()和stripslashes()这两个函数的功能。在PHP4.0及以上的版本中,该选项默认情况下是开启的,所以在PHP4.0及以上的版本中,就算PHP程序中的参数没有进行过滤,PHP系统也会对每一个通过GET、POST、COOKIE方式传递的变量自动转换,换句话说,输入的注入攻击代码将会全部被转换,将给攻击者带来非常大的困难。
虽然如此,攻击者仍然有机会进行SQL注入攻击。。。。。。前提是,当参数为数字型的时候,且未经过Intval()函数的处理,因为经过intval()的处理之后,所有的数据就都会强制转换成数字。
前面已经提到过,开启magic_quote_gpc=on之后,相当于使用addslshes()这个函数。但是数字型没有用到单引号,所以理所当然的绕过了addslshes()函数的转换了。而使用MySQL自带的char()函数或者HEX(),char()可以将参数解释为整数并且返回这些整数的ASCII码字符组成的字符串,使用十六进制表示必须在数字前加上0x。
实例演示:
假设我们知道管理员的用户名为admin,密码不知道。并且已经将magic_quote_gpc启用。
SQL语句:$sql="select * from users where username=$name and password='$pwd'";注意:变量$name没加引号
此时,在地址栏中输入username=admin%23,则合成后的sql语句为:
  select * from users where username='admin\' #' and password='';
  这时候通过url地址栏输入的单引号(')将被加上反斜线,该sql语句将失效。
  admin转换成ASCII后是char(97,100,109,105,110)
  此时在地址栏中输入username=char(97,100,109,105,110)%23
  SQL语句就变成了:
  select * from users where username=char(97,100,109,105,110)#' and password='';
  执行结果为真,就可以顺利进入后台。
  对于数字型注入攻击,必须在任何的数字型参数放入数据库之前使用intval()对参数进行强制转换成数字,从而可以断绝数字型注入漏洞的产生。
  比如:$id=intval($_GET[‘id']);
  select * from articles where id='$id';
  地址栏中输入:id=5' or 1=1%23
  SQL语句将变成:select * from articles where id='5';
  而不是select * from articles where id='5' or 1=1#;
总结:
对于每一个变量都记得加上单引号,比如where username='$name',
开启magic_quote_gpc并不是绝对安全的,对于数字型注入攻击,仅仅使用addslashes()函数进行转换是不够的,还需使用intval()强制将参数转换成数字
如何防止SQL注入攻击
方法一:密码比对
思路:首先通过用户输入的用户名去查询数据库,得到该用户名在数据库中对应的密码,再将从数据库中查询到的密码和用户提交过来的密码进行比对。
代码:
</div> </div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 浅谈开启magic_quote_gpc后的sql注入攻击与防范

相关文章

  • 2018-12-05sql2005 数据同步方法
  • 2018-12-05SQL Server自动更新统计信息的基本算法
  • 2018-12-05MYSQL中utf8_general_ci和utf8_unicode_ci的区别
  • 2018-12-05SQLServer 常用语句(按功能分)
  • 2018-12-05Mysql修改字符集语句
  • 2018-12-05 MongoDB循序渐进之[入门]
  • 2018-12-05深入理解MySQL进阶漂流记(三)
  • 2018-12-05MYSQL学习总结(五):MYSQL主从搭建
  • 2018-12-05MySQL EXPLAIN 命令详解学习
  • 2018-12-05MySQL 5.6 (Win7 64位)下载、安装与配置图文教程_MySQL

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • MySQL 存储过程传参数实现where id in(1,2,3,...)示例
    • MySQL · 引擎特性 · InnoDB IO子系统的详细介绍
    • 通过mysql show processlist 命令检查mysql锁的方法
    • 加速PHP动态网站 MySQL索引分析和优化
    • mysql数据库基础语句训练题详细代码
    • MySQL性能优化 出题业务SQL优化
    • MySQL中不能创建自增字段的解决方法
    • MySQL学习笔记1:安装和登录(多种方法)
    • 关于mysqli_affected_rows()函数的详细介绍
    • 详解MySQL的replication双向备份配置

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有