如果充分利用了ASP.NET的特點,結合配置檔案,如global.asax、web.config等,結合使用Application和Session,可以實作很多看似複雜,實際非常容易實作的問題。下面簡單介紹使用application和global.asax實作的一個簡單的線上使用者統計。
一、使用者顯示頁面的使用
<%@ Page Language="c#" debug="true" %>
<html>
<head>
<SCRIPT LANGUAGE="c#" RUNAT="server">
private void Page_Load(object sender, System.EventArgs e)
{
Visitors.Text = "本站目前有: <b>" + Application["user_sessions"].ToString() + "" + "</b> 位通路者 !";
}
<title>線上使用者</title>
</head>
<body>
<asp:label id="visitors" runat="server" /><br>
</body>
</html>
二、global.asax檔案實作
<script language="c#" runat="Server">
protected void Application_Start(Object sender, EventArgs e)
Application["user_sessions"] = 0;
protected void Session_Start(Object sender, EventArgs e)
Application.Lock();
Application["user_sessions"] = (int)Application["user_sessions"] + 1;
Application.Unlock();
protected void Session_End(Object sender, EventArgs e)
Application["user_sessions"] = (int)Application["user_sessions"] - 1;
</script>
以上代碼很容易了解,當網站開始服務的時候(Application開始的時候),程式設定Application["user_sessions"]為零,然後,當使用者進入網站(Session開始的時候)的時候,鎖定Application,然後,将application("user_sessions")加一,使用者退出網站的時候,application("user_sessions")減一。這樣,就很巧妙的實作了線上使用者的統計。
三、一點讨論
以上的統計,簡明扼要,程式很容易實作。但是,如果我們仔細考慮,發現該方法有一定的局限,統計出來的線上使用者數量可能稍微有點誤差。因為我們在以上程式中,是根據使用者建立和退出會話(Session)來實作線上人數的加減的,而我們知道,如果使用者沒有關閉浏覽器,而進入另外一個網站,那麼,這個會話在一定的時間内是不會結束的,這個時間我們可以通過TimeOut來設定,一般的,我們設定為20分鐘。是以,在使用者數量統計上面,還是存在一點誤差的。
另外,我們知道,在ASP中,如果使用者将浏覽器上面的Cookies設定為“禁用”,那麼,Session就不能再被傳遞,顯然,這樣設定讓以上的統計程式無能為力。不過,在ASP.NET中我們有解決方法,在config.web檔案中,我們将<sessionstate cookieless="false" />設定為true就可以了,也就說,不使用Cookies也可以傳遞Session。這樣,我們的程式就可以在不同的通路者環境中順利運作。
如果充分利用web.config等配置檔案,可以充分展現asp.net的優勢和特性,可以将連接配接資料庫的字元串寫在配置檔案中,這樣,既實作了安全性,也更易于程式的維護。如:
<configuration>
<appSettings>
<add key="conn_Default" value="workstation id=server name;packet size=4096;data source=server name;initial catalog=database name;persist security info=True;user id=sa;pwd = ;"></add>
</appSettings>
other settings here
</configuration>
那麼就可以在連接配接資料庫時使用如下的代碼:
// ===資料庫連接配接串設定===
public static readonly string conn_Default = ConfigurationSettings.AppSettings["conn_Default"]; // 系統預設資料庫連接配接串
本文轉自 august 51CTO部落格,原文連結:http://blog.51cto.com/august/6943,如需轉載請自行聯系原作者