1. 사용자 정보를 저장할 IPStat 데이터 테이블을 생성합니다
IPStat 테이블에 저장하는 사용자 정보에는 로그인한 사용자의 IP(IP_Address), IP 소스(IP_Src) 및 로그인 시간( IP_DateTime ), 이 테이블의 정보를 하루 동안만 저장합니다. 매월 정보를 계산하려면 한 달 동안 저장합니다. 데이터 로그의 운용에 대해 잘 몰라서 이 테이블을 만들었는데, 바보라고 하세요, 하하.
2. 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(); }
3. 위의 관련 정보를 추가합니다. 데이터베이스 IPStat에 저장
IPControl() 클래스를 생성하여 데이터베이스 IPStat 데이터를 작동하는 데 사용됩니다. IPControl() 클래스의 내용은 C#의 데이터베이스에 대한 작업이므로 SQL 서버 데이터베이스를 이해하면 이해할 수 있습니다. 여기서는 링크를 클릭하여 살펴보시기 바랍니다.
사용자 IP 정보를 데이터베이스에 저장하려면 위 코드에서 IPControl()을 호출하세요.
//保存IP信息到数据库中 IPControl cont = new IPControl(); cont.AddIP(ipAddress, ipSrc, ipDatetime);
파라미터 ipAddress는 사용자 IP, ipSrc는 사용자 소스, ipDatetime은 사용자 입장 시간.
4. 타이머를 생성하고 관련 데이터를 정기적으로 운영
위의 IPsta 데이터베이스 데이터에 대해 하나 또는 여러 개의 타이머를 생성하고 매일 밤 24시 이전에 10초 이내에 설정해야 합니다. 하루 동안의 트래픽을 삭제한 후 해당 페이지의 통계 결과를 다른 데이터 테이블에 저장하여 어제의 방문 횟수를 표시합니다. 타이머를 생성하고 사용하려면 참조용으로 하나 또는 여러 개의 타이머를 생성하려면 클릭하세요.
위 내용 중 부정확한 부분이 있으면 비판하고 정정해 주시기 바랍니다. 감사해요!
ASP.net의 웹사이트 방문 통계 방법 - IP 데이터 정보를 얻기 위한 클래스
using System; using System.Data; using System.Data.SqlClient; using System.Text; /// /// 获取IP数据信息的类 /// public class IPControl { //常量用来表示T-SQL语句中用到的变量名称 private const string PARM_IP_ADDRESS = "@IPAddress"; private const string PARM_IP_SRC = "@IPSrc"; private const string PARM_IP_DATETIME = "@IPDateTime"; //T-SQL语句 private const string SQL_INSERT_IPSTAT = "INSERT INTO IPStat VALUES(@IPAddress,@IPSrc,@IPDateTime)"; private const string SQL_DELETE_IPSTAT = "delete from IPStat WHERE DATEDIFF(d,ip_datetime,getdate())>30"; //只保留一个月的数据 private const string SQL_SELECT_TOTAL = "SELECT COUNT(*) FROM IPStat "; private const string SQL_SELECT_TODAY = "SELECT COUNT(*) FROM IPStat WHERE DATEDIFF(d,ip_datetime,getdate())=0"; private const string SQL_SELECT_YESTERDAY = "SELECT COUNT(*) FROM IPStat WHERE DATEDIFF(d,ip_datetime,getdate())=1"; private const string SQL_SELECT_MONTH = "SELECT COUNT(*) FROM IPStat WHERE DATEDIFF(d,ip_datetime,getdate())<30 and DATEDIFF(mm,ip_datetime,getdate())=0"; public IPControl() { } /// /// 保存IP数据信息到数据库 /// /// /// public void AddIP(string ipAddress,string ipSrc,DateTime ipDatetime) { //构建连接语句字符串 StringBuilder strSQL = new StringBuilder(); //创建表示QQ号的参数 SqlParameter[] parms = new SqlParameter[] { new SqlParameter(PARM_IP_ADDRESS, SqlDbType.NVarChar, 20), new SqlParameter(PARM_IP_SRC, SqlDbType.NVarChar,80), new SqlParameter(PARM_IP_DATETIME, SqlDbType.DateTime)}; SqlCommand cmd = new SqlCommand(); // 依次给参数赋值,并添加到执行语句中 parms[0].Value = ipAddress; parms[1].Value = ipSrc; parms[2].Value = ipDatetime; foreach(SqlParameter parm in parms) cmd.Parameters.Add(parm); //定义对象资源保存的范围,一旦using范围结束,将释放对方所占的资源 using (SqlConnection conn = new SqlConnection(SqlHelper.ConnectionStringLocalTransaction)) { //在执行字符串中加载插入语句 strSQL.Append(SQL_INSERT_IPSTAT); conn.Open(); //设定SqlCommand的属性 cmd.Connection = conn; cmd.CommandType = CommandType.Text; cmd.CommandText = strSQL.ToString(); //执行SqlCommand命令 cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); //如果执行成功,返回true,否则false。 } } public string GetTotal() { //调用SqlHelper访问组件的方法返回第一行第一列的值 object count = SqlHelper.ExecuteScalar(SqlHelper.ConnectionStringLocalTransaction, CommandType.Text, SQL_SELECT_TOTAL, null); //返回统计结果 return count.ToString(); } public string GetToday() { //调用SqlHelper访问组件的方法返回第一行第一列的值 object count = SqlHelper.ExecuteScalar(SqlHelper.ConnectionStringLocalTransaction, CommandType.Text, SQL_SELECT_TODAY, null); //返回统计结果 return count.ToString(); } public string GetYesterday() { //调用SqlHelper访问组件的方法返回第一行第一列的值 object count = SqlHelper.ExecuteScalar(SqlHelper.ConnectionStringLocalTransaction, CommandType.Text, SQL_SELECT_YESTERDAY, null); //返回统计结果 return count.ToString(); } public string GetMonth() { //调用SqlHelper访问组件的方法返回第一行第一列的值 object count = SqlHelper.ExecuteScalar(SqlHelper.ConnectionStringLocalTransaction, CommandType.Text, SQL_SELECT_MONTH, null); //返回统计结果 return count.ToString(); } }
Global.asax의 타이머를 사용하여 온라인 사용자 수와 일별 및 월별 방문 수 계산
1. Application_Start에서 타이머를 생성합니다
//以下为使用多个定时器System.Timers.Timer的处理方法 //用thread重新包一下,定义两个定时器 System.Threading.Thread myTimer_1 = new System.Threading.Thread(new System.Threading.ThreadStart(write_1)); myTimer_1.Start(); System.Threading.Thread myTimer_2 = new System.Threading.Thread(new System.Threading.ThreadStart(write_2)); myTimer_2.Start();
2. 타이머를 사용하여 10분마다 온라인 인원 수를 업데이트하고 하루 트래픽 정보를 저장할지 확인합니다
//使用第一个定时器,每10分钟更新一次在线人数 private void write_1() { //以下使用System.Timers.Timer类 每间隔10分钟存一次数据 System.Timers.Timer myTimer1 = new System.Timers.Timer(600000); //实例化Timer类,设置间隔时间为600000毫秒(10分钟存一次总人数); myTimer1.Enabled = true; //是否执行System.Timers.Timer.Elapsed事件; myTimer1.Elapsed += new System.Timers.ElapsedEventHandler(myTimer_Elapsed); //到达时间的时候执行事件myTimer_Elapsed; myTimer1.AutoReset = true; //设置是执行一次(false)还是一直执行(true); } //使用第二个定时器, private void write_2() { //以下使用System.Timers.Timer类 每间隔10分钟检查一次是否要存入一天流量的信息 System.Timers.Timer myTimer2 = new System.Timers.Timer(600000); //实例化Timer类,设置间隔时间为600000毫秒(10分钟存一次总人数); myTimer2.Enabled = true; //是否执行System.Timers.Timer.Elapsed事件; myTimer2.Elapsed += new System.Timers.ElapsedEventHandler(myTimer_peopleDay); //到达时间的时候执行事件myTimer_peopleDay; myTimer2.AutoReset = true; //设置是执行一次(false)还是一直执行(true); }
3 , 온라인 인원수를 처리하고 일별, 월별, 연간 트래픽을 계산하는 myTimer 프로세스를 만듭니다
//创建 myTimer_Elapsed 过程并定义第一个定时器事件,要用来处理在线人数的代码 private void myTimer_Elapsed(object sender, System.Timers.ElapsedEventArgs e) { //如果现在的在现人数大于原有的在现人数,则替换数据表中的在现人数 int MaxOnline = Convert.ToInt32(Application["OnlineMax"]); int MinOnline = Convert.ToInt32(Application["OnlineWhx"]); if (MaxOnline < MinOnline) { SqlConnection con = Db.DB.createconnection(); con.Open(); SqlCommand cmd = new SqlCommand("update countpeople set totol='" + Application["countSession"].ToString() + "',OnLine=+'" + Application["onlineWhx"] + "',DataTimes='" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "'", con); cmd.ExecuteNonQuery(); con.Close(); Application["OnlineMax"] = Application["OnlineWhx"]; //将现在线人数赋于OnlineMax Application["dataTimes"] = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"); } else { //将总访问人数写入数据库 SqlConnection con = Db.DB.createconnection(); con.Open(); SqlCommand cmd = new SqlCommand("update countpeople set totol=" + Application["countSession"].ToString(), con); cmd.ExecuteNonQuery(); con.Close(); } } //创建 myTimer_peopleDay 过程并定义第二个定时器事件,要用来统计每日、月、年的流量 private void myTimer_peopleDay(object sender, System.Timers.ElapsedEventArgs e) { try { //当天晚上24时 if (DateTime.Now.Hour == 23) { if (DateTime.Now.Minute >= 50) { //当天晚上24时,写入一天的流量 //初始化一个iP数据访问对象 IPControl cont = new IPControl(); //获取今天访问量 Int32 countToday = Convert.ToInt32(cont.GetToday()); //获取本月访问量 Int32 countMonth = Convert.ToInt32(cont.GetMonth()); //存储过程名sp_InsertCountPeopleDay SqlConnection con1 = Db.DB.createconnection(); con1.Open(); SqlCommand cmd1 = new SqlCommand("sp_InsertCountPeopleDay", con1); cmd1.CommandType = CommandType.StoredProcedure; //存储过程名 //调用并设置存储过程参数 cmd1.Parameters.Add(new SqlParameter("@peopleDay", SqlDbType.Int)); cmd1.Parameters.Add(new SqlParameter("@dateTimes", SqlDbType.DateTime)); //给参数赋值 cmd1.Parameters["@peopleDay"].Value = countToday; cmd1.Parameters["@dateTimes"].Value = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"); cmd1.ExecuteNonQuery(); con1.Close(); //在一个月的最后一天写入本月的访问量 //取本月最后一天(30或者31日) DateTime lastDay = Convert.ToDateTime(DateTime.Now.AddMonths(1).ToString("yyyy-MM-01")).AddDays(-1); int lastDay1 = DateTime.Now.Day; //取当前时间的日期 if (lastDay1.ToString() == lastDay.ToString()) //如果前日期等于本月最后一天的日期,则前本月的流量写入数据库 { SqlConnection conM = Db.DB.createconnection(); conM.Open(); SqlCommand cmdM = new SqlCommand("sp_InsertCountPeopleMonth", conM); cmdM.CommandType = CommandType.StoredProcedure; //存储过程名 //调用并设置存储过程参数 cmdM.Parameters.Add(new SqlParameter("@peopleMonth", SqlDbType.Int)); cmdM.Parameters.Add(new SqlParameter("@dateTimeMonth", SqlDbType.DateTime)); //给参数赋值 cmdM.Parameters["@peopleMonth"].Value = countMonth; cmdM.Parameters["@dateTimeMonth"].Value = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"); cmdM.ExecuteNonQuery(); conM.Close(); } } } } catch { } }
ASP.net의 웹사이트 트래픽 통계 메서드 코드와 관련된 더 많은 기사를 보려면 주의하세요. PHP 중국어 웹사이트로!