日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

解析asp中緩存cache技術(shù)的應(yīng)用_ASP教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:淺析asp無組件上傳并插入到數(shù)據(jù)庫里
以下為引用的內(nèi)容: % Response.Buffer = True Server.ScriptTimeOut=9999999 On Error Resume Next %>

ASP從發(fā)布至今已經(jīng)7年了,使用ASP技術(shù)已經(jīng)相當(dāng)成熟,自從微軟推出了ASP.NET之后就逐漸停止了對ASP版本的更新。但是由于有很多人仍然習(xí)慣使用ASP來開發(fā)網(wǎng)站,所以,再次我將以一個簡單的例子來說明在ASP中如何使用Cache。

簡單的說使用Cache基本原理是,把經(jīng)常需要且獲得代價昂貴的數(shù)據(jù)在內(nèi)存中持續(xù)保存一定時間,以供這些數(shù)據(jù)可以被直接地全局地訪問。例如,有一些數(shù)據(jù)需要從數(shù)據(jù)庫多個表中查詢獲得,且?guī)缀趺總頁面都要調(diào)用這些數(shù)據(jù)。

這種情況下的最佳實現(xiàn)就是將這部分數(shù)據(jù)Cache起來,在ASP中的簡單實現(xiàn)就是將這些數(shù)據(jù)的最終表達形式(例如HTML流)封裝在string中然后存入ASP內(nèi)置對象Application中(本文主要討論的是動態(tài)Cache,簡單的ASP 應(yīng)用就省略)。這樣做的好處是,在整個網(wǎng)站中可以全局調(diào)用這段HTML,而且Application是存在內(nèi)存中,所以不用再去查詢數(shù)據(jù)庫,從而加快了響應(yīng)時間并節(jié)省了服務(wù)器負荷。當(dāng)然這是以消耗內(nèi)存為代價的,是一個典型的以空間換時間的實例。

使用這種方法雖然有很多好處,但是再遇到頻繁變化的數(shù)據(jù)源(數(shù)據(jù)庫)的時候,這種方法就可能不再適用,因為ASP Application對象有一個缺點,就是不能自動隨數(shù)據(jù)源的變化而變化,或者控制刷新間隔。所以就需要開發(fā)人員編程來實現(xiàn)動態(tài)Cache。當(dāng)然在程序設(shè)計的時候可以在所有進行改變數(shù)據(jù)源(數(shù)據(jù)庫)操作時,就更新一次Appliction。從而使數(shù)據(jù)源(數(shù)據(jù)庫)始終保持一致。這樣做在編程上要考慮的問題會比較多,容易遺漏細節(jié)。所以除了特定情況我不推薦使用這種方法。

我認為在ASP中最好的辦法是用編程實現(xiàn)定時刷新Cache,也就是說給Application中儲存的設(shè)一個過期時間。當(dāng)然,在ASP中Application對象沒有這樣一個ExpireTime屬性。這需要用程序?qū)崿F(xiàn)。

以下為引用的內(nèi)容:
default.asp

<%@Language=VBScript%>
  <%Option Explicit%>
  <%Response.Buffer=True%>
  <!--#include file = "conn.asp"-->
  <!--#include file = "GetCache.asp"-->
  <HTML>
  <HEAD>
  <TITLE>ASP Cache演示</TITLE>
  <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=gb2312">
  </HEAD>
  <BODY>
  <h4>每隔10秒刷新Cache:</h4>
  <%
  response.Flush
  GetHTMLStream
  response.Write
  HTMLStream
  %>
  </body>
  </html>

以下為引用的內(nèi)容:
getcache.asp
<%
  Const CACHE_DEFAULT_INTERVAL = 30 &apos;每隔30秒刷新一次cache
  Dim HTMLStream
  Dim IsExpires
  IsExpires = CacheExpires
  Function CacheExpires
  Dim strLastupdate
  Dim result strLastupdate = Application("Lastupdate")
  If (strLastupdate = "") Or (CACHE_DEFAULT_INTERVAL < DateDiff("s", strLastupdate, Now)) Then
  result = true
  SetLastupdateTime
  Else
  result = false
  End If
  CacheExpires = result
  End Function

 

  Sub SetLastupdateTime
  Application.Lock
  Application("Lastupdate") = CStr(now())
  Application.UnLock
  End Sub
  Sub GetHTMLStream
  If IsExpires Then
  updateHTMLStream
  End If
  HTMLStream=Application("CACHE_HTMLStream")
  End Sub

以下為引用的內(nèi)容:
Sub updateHTMLStream
  dim d
  d = FetchHTMLStream
  Application.Lock
  Application("CACHE_HTMLStream") = d
  Application.UnLock
  End Sub

 

  Function FetchHTMLStream
  Dim rs ,strSQL, strHTML
  Set rs = createObject("ADODB.Recordset")
  strSQL = "select categoryID , categoryname from categories"
  rs.Open strSQL, strConn,adOpenForwardOnly,adLockReadOnly
  strHTML = strHTML & "<select name=""slt_search"">"
  while (not rs.EOF)
  strHTML = strHTML & "<option>"
  strHTML = strHTML & rs.Fields("categoryname")
  strHTML = strHTML & "</option>" rs.MoveNext
  wend
  strHTML = strHTML & "</select>"
  rs.Close
  Set rs = Nothing
  FetchHTMLStream = strHTML
  End Function
  %>

以下為引用的內(nèi)容:
conn.asp
<!--METADATA NAME="Microsoft ActiveX Data Objects 2.5 Library" TYPE="TypeLib" UUID="{00000205-0000-0010-8000-00AA006D2EA4}"-->
  <%
  dim strConn
  strConn = "Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=Northwind"
  %>

分享:如何用ASP顯示ACCESS數(shù)據(jù)庫的的GIF圖象
寫入: 1:把gif圖像文件讀入內(nèi)存(一個變量strTemp)。 2:寫入數(shù)據(jù)庫。 以下為引用的內(nèi)容:  Dim binTmp() As Byte  Dim conn As ADODB.Conn

來源:模板無憂//所屬分類:ASP教程/更新時間:2009-08-22
相關(guān)ASP教程