下面首先介紹我測試使用的一個例子:
首先在 global.asax 中的 Application_OnStart 事件過程中定義計時器,代碼如下:
[VB.Net] global.asax
<%@ import Namespace="System.Timers" %>
<script runat="server">
Sub Application_OnStart(sender As Object, e As EventArgs)
'' 創建一個計時器,單位:毫秒
Dim aTimer As New System.Timers.Timer(10000)
'' 將 Fresher 指定為計時器的 Elapsed 事件處理程序
AddHandler aTimer.Elapsed, AddressOf Fresher
'' AutoReset 屬性為 true 時,每隔指定時間循環一次;
'' 如果為 false,則只執行一次。
aTimer.AutoReset = True
aTimer.Enabled = True
'' 先給 Application("TimeStamp") 指定一個初值
Application.Lock()
Application("TimeStamp") = DateTime.Now.ToString()
Application.UnLock()
End Sub
Sub Fresher(sender As Object, e As ElapsedEventArgs)
Application.Lock()
Application("TimeStamp") = DateTime.Now.ToString()
Application.UnLock()
End Sub
</script>
然後我們簡單寫一個 test.ASPx 來查看 Application("TimeStamp") 的值。代碼如下:
[VB.Net] test.ASPx
<%
Response.Write(Application("TimeStamp"))
%>
分析:
根據 global.asax 中的代碼,我們設定了一個計時器,每隔 10 秒鐘執行一次 Fresher() 過程;在 Fresher() 過程中我們事實上只是重新寫入了一個 Application("TimeStamp") 新值。換句話說,Application("TimeStamp") 的值是應該每隔 10 秒鐘更新一次的。
是不是這樣的呢?通過 test.ASPx 的反復刷新觀察 Application("TimeStamp") 的值,的確發現這個值在每隔 10 秒地變化一次,而其他時候則保持不變。與我們的預期是一致的。
意義:
$False$通過引入計時器我們可以在 ASP.Net 的全局性程序(Application)中靈活的使用計時器完成一些定時操作,比如:在社區/論壇系統中,每隔 5 分鐘更新一次在線用戶列表,每隔 1 個小時更新一次用戶經驗值,或者每隔一天備份一次關鍵數據等等。這個思路應該是很誘人的。
探討:
Q: 是否在 ASP.Net 代碼的任何地方都可以使用計時器呢?
A: 我沒有測試過在普通 *.aspx 中插入計時器的情形。但從 B/S 程序的特點來看,即使在 *.ASPx 中插入計時器可行,也不是一種好的選擇。因為對於 B/S 程序來說,服務器接到客戶端的請求本身就是一個事件,在這個事件處理過程中,服務器必須迅速的作出回應,為客戶端產生相應的 Html 代碼,然後結束這一過程。如果在 *.aspx 使用計時器(如果允許的話),則第一沒有太大必要,第二很容易使系統因為插入的計時器過多(因為每一次 *.ASPx 的執行都有可能插入一個新的計時器)而使系統癱瘓。
因此,我建議只在 global.asax 的 Application_OnStart 中使用比較安全一些。歡迎對此感興趣的朋友對此發表見解
< meta http-equiv="Refresh" content="3"
url=http://www.cenpok.Net">
FirstTimer=new System.Timers.Timer((60-System.DateTime.Now.Second)*1000); \\計算整數
//關聯事件
//將 FirstTimer_Elapsed 指定為計時器的 Elapsed 事件處理程序
FirstTimer.Elapsed += new System.Timers.ElapsedEventHandler(FirstTimer_Elapsed);
// AutoReset 屬性為 true 時,每隔指定時間循環一次;
// 如果為 false,則只執行一次。
FirstTimer.AutoReset = false ;
FirstTimer.Enabled = true ;
1.用數據庫觸發器,當該表發生UPDATE事件時觸發!
2.寫一ASP,判斷你的表是否發生更新.以下是不斷發送請求的ASP
<head>
... ...
<script language=Javascript>
function Test()
{
var xmlhttp = new ActiveXObject("MSXML2.XMLHTTP");
XMLhttp.open("POST","abc.asp",false); // 向abc.ASP發送更新請求
XMLhttp.setRequestHeader("CONTENT-TYPE","application/x-www-form-urlencoded");
XMLhttp.send();
}
setInterval("Test();",10); // 10秒鐘發送一次更新請求
</script>
... ...