最为经典的单引号判断法: 在参数后面加上单引号,比如:

  http://xxx/abc.php?id=1'

  如果页面返回错误,则存在 Sql 注入。 原因是无论字符型还是整型都会因为单引号个数不匹配而报错。

  通常 Sql 注入漏洞分为 2 种类型:

  数字型

  字符型

  数字型判断:

  当输入的参 x整型时,通常 abc.php 中 Sql 语句类型大致如下: select * from <表名> where id = x 这种类型可以使用经典的 and 1=1 和 and 1=2 来判断:

  Url 地址中输入 http://xxx/abc.php?id= x and 1=1 页面依旧运行正常,继续进行下一步。

  Url 地址中继续输入 http://xxx/abc.php?id= x and 1=2 页面运行错误,则说明此 Sql 注入为数字型注入。

  原因如下: 当输入 and 1=1时,后台执行 Sql 语句:

  select * from <表名> where id = x and 1=1

  没有语法错误且逻辑判断为正确,所以返回正常。

  当输入 and 1=2时,后台执行 Sql 语句:

  select * from <表名> where id = x and 1=2

  没有语法错误但是逻辑判断为假,所以返回错误。 我们再使用假设法:如果这是字符型注入的话,我们输入以上语句之后应该出现如下情况:

  select * from <表名> where id = 'x and 1=1' select * from <表名> where id = 'x and 1=2'

  查询语句将 and 语句全部转换为了字符串,并没有进行 and 的逻辑判断,所以不会出现以上结果,故假设是不成立的。

  字符型判断:

  当输入的参 x 为字符型时,通常 abc.php 中 SQL 语句类型大致如下: select * from <表名> where id = 'x' 这种类型我们同样可以使用 and '1'='1 和 and '1'='2来判断:

  Url 地址中输入 http://xxx/abc.php?id= x' and '1'='1 页面运行正常,继续进行下一步。

  Url 地址中继续输入 http://xxx/abc.php?id= x' and '1'='2 页面运行错误,则说明此 Sql 注入为字符型注入。同理

最新文章

  1. 用SQL命令查看Mysql数据库大小
  2. 中文 iOS/Mac 开发博客列表(转)
  3. Qt and C++ Reflection,利用Qt简化C++的反射实现
  4. hdu 4049 2011北京赛区网络赛J 状压dp ***
  5. storm配置项目
  6. Win7精简成功后的总结
  7. 工作中Linux常用命令
  8. 小菜的系统框架界面设计-数据的完美呈现(DataGridView扩展)
  9. c++基础(二):成员he派生类
  10. BASE64Encoder问题类
  11. Linux驱动技术(一) _内存申请
  12. 【MySQL】 清除等待连接
  13. Cookie常用操作以及属性
  14. 前端菜鸟学习之DOM事件处理
  15. 机器学习总结(二)bagging与随机森林
  16. ubuntu14/16 安装python3-opencv3_百度经验
  17. Unsafe 学习和源码阅读
  18. POJ 2725
  19. [原] ubuntu 13.10 安装 winqq2013
  20. python第三十一课--递归(3.递归的弊端)

热门文章

  1. jQuery html操作
  2. bitset优化背包问题
  3. magento 获得当前产品页面的产品id
  4. 使用dubbox开发REST应用
  5. java中实参与形参的概念
  6. DEV—【GridControl主从表】
  7. Spring注解驱动开发之AOP
  8. Java 线程实例 刷碗烧水和倒计时
  9. Android开发使用的常见第三方框架汇总
  10. 未找到框架&ldquo;.NETFramework,Version=v4.5&rdquo;的引用程序集