程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> 在ASP.net中網站訪問量統計方法

在ASP.net中網站訪問量統計方法

編輯:.NET實例教程

.

一位QQ好友問我個人網站訪問量是如何統計的,由於本人初學做網站,水平有限,所介紹的方法可能是笨方法,但在我網站上能夠湊合著使用,希望大家多多指教。

一、建立一個數據表IPStat用於存放用戶信息

我在IPStat表中存放的用戶信息只包括登錄用戶的IP(IP_Address),IP來源(IP_Src)和登錄時間(IP_DateTime),些表的信息本人只保存一天的信息,如果要統計每個月的信息則要保存一個月。因為我不太懂對數據日志的操作,所以創建此表,所以說我笨吧,哈哈。

二、在Global.asax中獲取用戶信息

在Global.asax的Session_Start即新會話啟用時獲取有關的信息,同時在這裡實現在線人數、訪問總人數的增量統計,代碼如下:

void Session_Start(object sender, EventArgs e)

{

//獲取訪問者的IP

string ipAddress = Request.ServerVariables["REMOTE_ADDR"];

//獲取訪問者的來源

string ipSrc;

//判斷是否從搜索引擎導航過來的

if (Request.UrlReferrer == null)

{

ipSrc = "";

}

else

{

//獲取來源地址

ipSrc = Request.UrlReferrer.ToString();

}

//獲取訪問時間

DateTime ipDatetime = DateTime.Now;

//保存IP信息到數據庫中

IPControl cont = new IPControl();

cont.AddIP(ipAddress, ipSrc, ipDatetime);


//獲取用戶訪問的頁面

string pageurl = Request.Url.ToString();

//判斷訪問的是否是默認頁

if (pageurl.EndsWith("IPStat.ASPx"))

{

//鎖定變量

Application.Lock();

//為頁面訪問量+1

Application["StatCount"] = int.Parse(Application["StatCount"].ToString()) + 1;

//解鎖

Application.UnLock();

}


//鎖定變量

Session.Timeout = 10; //設定超時為10分鐘

Application.Lock();

Application["countSession"] = Convert.ToInt32(Application["countSession"]) + 1;  //訪問總人數+1

Application["onlineWhx"] = (int)Application["onlineWhx"] + 1; //在線人數加+1

Session["login_name"] = null;

//解鎖

Application.UnLock();

}


提醒一句,別忘了下面的代碼,以實現在用戶離線時,將在線人數減去1.


void Session_End(object sender, EventArgs e)

{

// 在會話結束時運行的代碼。

// 注意: 只有在 Web.config 文件中的 sessionstate 模式設置為 InProc 時,才會引發 Session_End 事件。

.

如果會話模式設置為 StateServer

// 或 SQLServer,則不會引發該事件。

//鎖定變量

Application.Lock();

Application["onlineWhx"] = (int)Application["onlineWhx"] - 1; //在線人數減-1

Session["login_name"] = null;

//解鎖

Application.UnLock();

}

三、將以上有關信息保存到數據庫IPStat

創建了一個獲取IP數據信息的類IPControl(),用來實現對數據庫IPStat數據的操作,關於IPControl()類的內容,因為它是C#中對數據庫的操作,以解SQL Server 數據庫,就能看懂它,這裡就不作介紹了,請點擊該鏈接查看。

為了實現將用戶IP信息存入數據庫,在上面代碼中對IPControl()進行調用

//保存IP信息到數據庫中

IPControl cont = new IPControl();

cont.AddIP(ipAddress, ipSrc, ipDatetime);

參數ipAddress為用戶IP,ipSrc為用戶來源, ipDatetime為用戶進入時間。 chinaitlab

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved