asp 靜態(tài)頁(yè)面的另一種思路
更新時(shí)間:2008年10月21日 13:51:47 作者:
最近的兩個(gè)網(wǎng)站的開發(fā)使我產(chǎn)生了不少新的想法!也閱讀過(guò)了不少優(yōu)秀的代碼,但總沒(méi)有找到一種符合自己的模式!借鑒緩存的設(shè)計(jì),我似乎找到了一種更便捷的思路。
其實(shí)這里的靜態(tài)頁(yè)面并不是真正意義上的靜態(tài),但可以達(dá)到了靜態(tài)頁(yè)面的解析效率,還未經(jīng)項(xiàng)目測(cè)試,拿來(lái)分享。
<%
Const DEVJS_INDEX="index.html"
Const INDEX_DEFAULT_INTERVAL=300
Dim sLastUpdate
'用Application保存最后更新的時(shí)間,而在頁(yè)面里做判斷,每隔300秒(5分鐘)就生成一次頁(yè)面
sLastUpdate=Application("INDEX_LAST_Update")
If sLastUpdate="" or DateDiff("s",sLastUpdate,now())>INDEX_DEFAULT_INTERVAL Then
'調(diào)用MakeIndex()生成頁(yè)面,同時(shí)更改最后更新時(shí)間
MakeIndex()
sLastUpdate=Now()
Application("INDEX_LAST_Update")=sLastUpdate
Response.Write "超出默認(rèn)時(shí)間,更新于" & sLastUpdate
Else
Response.Write "讀取靜態(tài)頁(yè)面,更新于" & sLastUpdate
End If
Response.Write LoadTextFile(Server.MapPath(DEVJS_INDEX),"GB2312")
Function MakeIndex()
sContent="<hr>" & Now()
Call SaveTextFile(Server.MapPath(DEVJS_INDEX),"GB2312",sContent)
End Function
%>
如果過(guò)期就更新頁(yè)面,沒(méi)有過(guò)期直接調(diào)用靜態(tài)頁(yè)面,這里還用到了兩個(gè)函數(shù),一并貼上,提醒注意一下,SaveTextFile()是以覆蓋方式寫入的
就是這一句 oStream.SaveToFile sFilePath,2
<%
Function LoadTextFile(sFilePath,sCharset)
Dim oStream
Set oStream=Server.CreateObject("ADODB.Stream")
oStream.Type=2
oStream.Mode=3
oStream.Open
oStream.Charset=sCharset
oStream.Position=oStream.Size
oStream.LoadFromFile sFilePath
LoadTextFile=oStream.ReadText
oStream.Close
Set oStream=Nothing
End Function
Function SaveTextFile(sFilePath,sCharset,outString)
SaveFile=false
Dim oStream
Set oStream = Server.CreateObject("ADODB.Stream")
oStream.Type=2
oStream.Mode=3
oStream.Open
oStream.Charset=sCharset
oStream.WriteText = outString
oStream.SaveToFile sFilePath,2
oStream.Close
Set oStream = Nothing
SaveTextFile=true
End Function
%>
這個(gè)比緩存省事,也直接的多!其實(shí),在MakeIndex()里可以做很多事,比如讀取模板文件進(jìn)行替換這些。
復(fù)制代碼 代碼如下:
<%
Const DEVJS_INDEX="index.html"
Const INDEX_DEFAULT_INTERVAL=300
Dim sLastUpdate
'用Application保存最后更新的時(shí)間,而在頁(yè)面里做判斷,每隔300秒(5分鐘)就生成一次頁(yè)面
sLastUpdate=Application("INDEX_LAST_Update")
If sLastUpdate="" or DateDiff("s",sLastUpdate,now())>INDEX_DEFAULT_INTERVAL Then
'調(diào)用MakeIndex()生成頁(yè)面,同時(shí)更改最后更新時(shí)間
MakeIndex()
sLastUpdate=Now()
Application("INDEX_LAST_Update")=sLastUpdate
Response.Write "超出默認(rèn)時(shí)間,更新于" & sLastUpdate
Else
Response.Write "讀取靜態(tài)頁(yè)面,更新于" & sLastUpdate
End If
Response.Write LoadTextFile(Server.MapPath(DEVJS_INDEX),"GB2312")
Function MakeIndex()
sContent="<hr>" & Now()
Call SaveTextFile(Server.MapPath(DEVJS_INDEX),"GB2312",sContent)
End Function
%>
如果過(guò)期就更新頁(yè)面,沒(méi)有過(guò)期直接調(diào)用靜態(tài)頁(yè)面,這里還用到了兩個(gè)函數(shù),一并貼上,提醒注意一下,SaveTextFile()是以覆蓋方式寫入的
就是這一句 oStream.SaveToFile sFilePath,2
復(fù)制代碼 代碼如下:
<%
Function LoadTextFile(sFilePath,sCharset)
Dim oStream
Set oStream=Server.CreateObject("ADODB.Stream")
oStream.Type=2
oStream.Mode=3
oStream.Open
oStream.Charset=sCharset
oStream.Position=oStream.Size
oStream.LoadFromFile sFilePath
LoadTextFile=oStream.ReadText
oStream.Close
Set oStream=Nothing
End Function
Function SaveTextFile(sFilePath,sCharset,outString)
SaveFile=false
Dim oStream
Set oStream = Server.CreateObject("ADODB.Stream")
oStream.Type=2
oStream.Mode=3
oStream.Open
oStream.Charset=sCharset
oStream.WriteText = outString
oStream.SaveToFile sFilePath,2
oStream.Close
Set oStream = Nothing
SaveTextFile=true
End Function
%>
這個(gè)比緩存省事,也直接的多!其實(shí),在MakeIndex()里可以做很多事,比如讀取模板文件進(jìn)行替換這些。
相關(guān)文章
asp控制xml數(shù)據(jù)庫(kù)的經(jīng)典代碼
本文為大家分享了六段經(jīng)典的asp控制xml數(shù)據(jù)庫(kù)代碼,感興趣的小伙伴們可以參考一下2015-09-09用ASP生成UTF-8網(wǎng)頁(yè)文件的兩種方法
用ASP生成UTF-8網(wǎng)頁(yè)文件的兩種方法...2007-07-07ASP模擬POST請(qǐng)求異步提交數(shù)據(jù)的方法
這篇文章主要介紹了ASP模擬POST請(qǐng)求異步提交數(shù)據(jù)的方法,本文使用MSXML2.SERVERXMLHTTP.3.0實(shí)現(xiàn)POST請(qǐng)求,需要的朋友可以參考下2014-07-07asp實(shí)現(xiàn)樹型結(jié)構(gòu)
asp實(shí)現(xiàn)樹型結(jié)構(gòu)...2007-03-03Microsoft JET Database Engine(0x80004005)未指定錯(cuò)誤的解決方法
今天在配置iis asp運(yùn)行環(huán)境的時(shí)候提示Microsoft JET Database Engine(0x80004005)未指定錯(cuò)誤,不過(guò)最后通過(guò)如下方法解決了,這里腳本之家小編特為大家分享下,方便需要的朋友2014-06-06