校庆网备忘

1:下周二 演示 校庆网

 

2:网站历史访问总人数   今天访问总人数

 

3:网站 校园 电子 地图  http://map.hit.edu.cn/(哈工大的  有意思)

 

下面转帖

 

一位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为用户进入时间。

四、创建定时器,定时操作有关数据

对以上IPSta 数据库的数据,需要创建一个或者几个定时器 ,并在每天晚上24时前的10秒钟内统计一天的流量,然后将其删除,把统计结果保存到另一个数据表中,供页面显示昨日访问量是调用。定时器的创建和使用请点击创建一个或者几个定时器 ,供你参考。

 

 

 

ASP.NET实现记录历史访问人数和当前在线人数

protected   void  Application_Start(Object sender, EventArgs e) // 当前应用程序启动这件事会发生
    {
      SqlConnection con
= new  SqlConnection( " server=.;database=countPeople;uid=sa;pwd=; " );
      con.Open();
      SqlCommand cmd
= new  SqlCommand( " select * from countPeople " ,con);
      
int  count = Convert.ToInt32(cmd.ExecuteScalar());
      con.Close();
      Application[
" total " ] = count; // Application是个全局变量,每个会话都可对他操作
      Application[ " online " ] = 0 ;
    }
protected   void  Session_Start(Object sender, EventArgs e) // 客户端一连接到服务器上,这个事件就会发生
    {
      Session.Timeout
= 1 ;
      Application.Lock();
// 锁定后,只有这个Session能够会话
      Application[ " total " ] = ( int )Application[ " total " ] + 1 ;
      Application[
" online " ] = ( int )Application[ " online " ] + 1 ;
      Application.UnLock();
// 会话完毕后解锁
    }
protected   void  Session_End(Object sender, EventArgs e) // 当会话结束时这个事件发生
    {
      Application.Lock();
      Application[
" online " ] = ( int )Application[ " online " ] - 1 ;
      Application.UnLock();
    }
protected   void  Application_End(Object sender, EventArgs e)) // 当前应用程序启动这件事会发生
    {
      SqlConnection con
= new  SqlConnection( " server=.;database=countPeople;uid=sa;pwd=; " );
      con.Open();
      SqlCommand cmd
= new  SqlCommand( " updata countPeople set num= " + Application[ " total " ],con);
      cmd.ExecuteNonQuery();
      con.Close();
    }

private   void  Page_Load( object  sender, System.EventArgs e)
    {
      
this .lblTotal.Text = Application[ " total " ].ToString(); // 历史访问人数
       this .lblOnline.Text = Application[ " online " ].ToString(); // 当前在线人数
      
//  在此处放置用户代码以初始化页面
    }

 

 

http://100.scau.edu.cn/xsztw/wish/index.asp

 

 

http://90.ysu.edu.cn/message.php

 

 

http://90.ysu.edu.cn/message.php

 

 

http://xiaoqing.sust.edu.cn/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值