學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 網(wǎng)絡(luò)知識 > 網(wǎng)絡(luò)技術(shù) >

ASP數(shù)據(jù)庫被掛馬怎么解決

時(shí)間: 加城1195 分享

  數(shù)據(jù)庫掛馬應(yīng)該有用戶遇到過,而且很多人都不知道怎么處理,在這里,小編講下ASP數(shù)據(jù)庫被掛馬的編程處理方法,你可以試用下,對你是否有幫助.

  方法步驟

  第一步:為現(xiàn)有數(shù)據(jù)庫做好備份。

  第二步:執(zhí)行如下ASP文件,這樣就可以去掉數(shù)據(jù)庫當(dāng)中的JS木馬:

  注:conn.asp自己去寫了。

  ’這里放入JS木馬內(nèi)容:請記得改為自己數(shù)據(jù)庫中的JS木馬內(nèi)容。

  如果數(shù)據(jù)庫表很多的話,上面的遍歷數(shù)據(jù)庫結(jié)構(gòu)未執(zhí)行完就被IIS給停止了。在這時(shí)候可以在:

  If rstSchema("TABLE_TYPE")="TABLE" Then

  當(dāng)中適當(dāng)加入k值的范圍,如:

  If rstSchema("TABLE_TYPE")="TABLE" k>10 and k<20 Then

  這樣的話就一次只操作9個(gè)表。

  第三步:

  根據(jù)數(shù)據(jù)庫JS注入的特性(會包括和http://這樣的字符),在conn.asp里面放入如下代碼:

  Function Cheack_Sqljs()’防止數(shù)據(jù)庫外鏈JS注入:true為發(fā)現(xiàn)外鏈JS注入。

  Dim F_Post,F_Get

  Cheack_Sqljs=False

  If Request.Form<>"" Then’表單提交時(shí)的檢測For Each F_Post In Request.Form If (Instr(LCase(Request.Form(F_Post)),"0 or Instr(LCase(Request.Form(F_Post)),"")<>0) and Instr(LCase(Request.Form(F_Post)),"http://")<>0 Then

  Cheack_Sqljs=True

  Exit For

  End If

  Next

  End If

  If Request.QueryString<>"" Then’QueryString提交時(shí)的檢測For Each F_Get In Request.QueryString If (Instr(LCase(Request.Form(F_Get)),"0 or Instr(LCase(Request.Form(F_Get)),"")<>0) and Instr(LCase(Request.Form(F_Get)),"http://")<>0 Then

  Cheack_Sqljs=True

  Exit For

  End If

  Next

  End If

  End Function

  Function CheckDataFrom()’檢查提交數(shù)據(jù)來源:True為數(shù)據(jù)從站外提交過來的

  CheckDataFrom=True

  server_v1=Cstr(Request.ServerVariables("HTTP_REFERER")) server_v2=Cstr(Request.ServerVariables("SERVER_NAME")) if mid(server_v1,8,len(server_v2))<>server_v2 then

  CheckDataFrom=False

  end if

  End Function

  If Cheack_Sqljs or CheckDataFrom Then

  Response.Write "" Response.End()

  End If

  一般是數(shù)據(jù)庫里有一張表里的內(nèi)容有 讀取數(shù)據(jù)庫或服務(wù)器的代碼,造成的,用管理數(shù)據(jù)庫軟件連接,刪除表里的記錄。

  補(bǔ)充:MySQL 數(shù)據(jù)庫常用命令

  create database name; 創(chuàng)建數(shù)據(jù)庫

  use databasename; 進(jìn)入數(shù)據(jù)庫

  drop database name 直接刪除數(shù)據(jù)庫,不提醒

  show tables; 顯示表

  describe tablename; 查看表的結(jié)構(gòu)

  select 中加上distinct去除重復(fù)字段

  mysqladmin drop databasename 刪除數(shù)據(jù)庫前,有提示。

  顯示當(dāng)前mysql版本和當(dāng)前日期

  select version(),current_date;

  數(shù)據(jù)庫維護(hù)方法

  在MySQL使用的過程中,在系統(tǒng)運(yùn)行一段時(shí)間后,可能會產(chǎn)生碎片,造成空間的浪費(fèi),所以有必要定期的對MySQL進(jìn)行碎片整理。

  當(dāng)刪除id=2的記錄時(shí)候,發(fā)生的現(xiàn)象

  這個(gè)時(shí)候發(fā)現(xiàn)磁盤的空間并沒有減少。這種現(xiàn)象就叫做碎片化(有一部分的磁盤空間在數(shù)據(jù)刪除以后(空),還是無法被操作系統(tǒng)所使用。)

  常見的優(yōu)化:

  # alter table xxx engine myisam;

  # optimize table t1;

  注意: 在實(shí)際開發(fā)的過程中,上面兩個(gè)語句盡量少使用,因?yàn)樵谑褂玫倪^程中,MySQL的表的結(jié)構(gòu)會整體全部重新整理,需要消耗很多的資源,建議在凌晨兩三點(diǎn)鐘的時(shí)候執(zhí)行。(在linux下有定時(shí)器腳本可以執(zhí)行,crontab)


數(shù)據(jù)庫相關(guān)文章:

1.怎么開啟SQL數(shù)據(jù)庫服務(wù)

2.sql數(shù)據(jù)庫的集合函數(shù)查詢

3.excel怎么將表格連入數(shù)據(jù)庫

4.把Excel數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫的方法

5.數(shù)據(jù)庫中default的用法

4014886