<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%> <% '讀取遠程文件的函數 Public Function readRemoteFile(RemoteDataUrl) Dim XMLHttp 'On Error Resume Next Set XMLHttp = Server.CreateObject("Microsoft.XMLHTTP") With XMLHttp .Open "Get", RemoteDataUrl, False .Send readRemoteFile = BytesToBstr(.responseBody, "UTF-8") End With Set XMLHttp = Nothing End Function '編碼轉換 Function BytesToBstr(body,Cset) dim objstream set objstream = Server.CreateObject("adodb.stream") objstream.Type = 1 objstream.Mode =3 objstream.Open objstream.Write body objstream.Position = 0 objstream.Type = 2 objstream.Charset = Cset BytesToBstr = objstream.ReadText objstream.Close set objstream = nothing End Function
Function tobody() Dim dateVal '先試圖訪問緩存,看有沒有,或者過期沒有 dateVal = Application("defaultdate") If dateVal = "" Then dateVal = DateAdd("s",1200,Now) If Application("default") <> "" Then If DateDiff("s", Now, dateVal) > 0 Then '如果有,就從緩存讀取,對服務器來說,就是從內存讀取 tobody = Application("default")&"<!--new cache"&dateVal&"-->" Exit Function End If End If Dim body '如果緩存沒有,則從遠程讀取,并寫入緩存,設置緩存時間。 body = readRemoteFile("http://www.aoaob.com/default.asp") tobody = body&"<!--made cache"&Now&"-->" Application.Lock Application("default") = body Application("defaultdate") = DateAdd("s",1200,Now) Application.UnLock End Function Response.Write(tobody()) %>