亚洲欧美精品沙发,日韩在线精品视频,亚洲Av每日更新在线观看,亚洲国产另类一区在线5

<pre id="hdphd"></pre>

  • <div id="hdphd"><small id="hdphd"></small></div>
      學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 網(wǎng)絡(luò)知識(shí) > 網(wǎng)絡(luò)技術(shù) >

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

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

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

        方法步驟

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

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

        注:conn.asp自己去寫了。

        ’這里放入JS木馬內(nèi)容:請(qǐng)記得改為自己數(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注入的特性(會(huì)包括和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í)的檢測(cè)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í)的檢測(cè)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í)間后,可能會(huì)產(chǎn)生碎片,造成空間的浪費(fèi),所以有必要定期的對(duì)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)會(huì)整體全部重新整理,需要消耗很多的資源,建議在凌晨兩三點(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