我的global代码:要实现关闭浏览器后,把在线人数的标记归0,但是就是没有效果,session的过期时间<sessionState mode="InProc" timeout="1"></sessionState><script RunAt="server"> void Application_Start(object sender, EventArgs e)
{
Application["count"] = 0;
}
void Application_End(object sender, EventArgs e)
{
//在应用程序关闭时运行的代码
}
void Application_Error(object sender, EventArgs e)
{
//在出现未处理的错误时运行的代码 } void Session_Start(object sender, EventArgs e)
{
//在新会话启动时运行的代码
Application.Lock();
Application["count"] = int.Parse(Application["count"].ToString()) + 1;
Application.UnLock();
} void Session_End(object sender, EventArgs e) //这里是代表session的默认时间结束时才会执行的,和直接关闭浏览器不一样
{
//在会话结束时运行的代码。
// 注意: 只有在 Web.config 文件中的 sessionstate 模式设置为
// InProc 时,才会引发 Session_End 事件。如果会话模式
//设置为 StateServer 或 SQLServer,则不会引发该事件。 string connstring = "Provider=Microsoft.Jet.Oledb.4.0;Data Source=" + System.Web.HttpContext.Current.Server.MapPath("lian1.mdb");
OleDbConnection con = new OleDbConnection(connstring);//实例化数据库连接类
con.Open();
string s = "Update user_login set zaixian=0 where name='" + Session["username"] + "'";//@na如果写成这样就错了,因为是PROTECTED的,在这里用不了,除非重新赋值参数;
OleDbCommand com = new OleDbCommand(s, con);
com.ExecuteNonQuery();
con.Close();
Application.Lock();
Application["count"] = int.Parse(Application["count"].ToString()) - 1;//在线人数减少一个
Application.UnLock();
}
</script>
麻烦高人帮看下吧
{
Application["count"] = 0;
}
void Application_End(object sender, EventArgs e)
{
//在应用程序关闭时运行的代码
}
void Application_Error(object sender, EventArgs e)
{
//在出现未处理的错误时运行的代码 } void Session_Start(object sender, EventArgs e)
{
//在新会话启动时运行的代码
Application.Lock();
Application["count"] = int.Parse(Application["count"].ToString()) + 1;
Application.UnLock();
} void Session_End(object sender, EventArgs e) //这里是代表session的默认时间结束时才会执行的,和直接关闭浏览器不一样
{
//在会话结束时运行的代码。
// 注意: 只有在 Web.config 文件中的 sessionstate 模式设置为
// InProc 时,才会引发 Session_End 事件。如果会话模式
//设置为 StateServer 或 SQLServer,则不会引发该事件。 string connstring = "Provider=Microsoft.Jet.Oledb.4.0;Data Source=" + System.Web.HttpContext.Current.Server.MapPath("lian1.mdb");
OleDbConnection con = new OleDbConnection(connstring);//实例化数据库连接类
con.Open();
string s = "Update user_login set zaixian=0 where name='" + Session["username"] + "'";//@na如果写成这样就错了,因为是PROTECTED的,在这里用不了,除非重新赋值参数;
OleDbCommand com = new OleDbCommand(s, con);
com.ExecuteNonQuery();
con.Close();
Application.Lock();
Application["count"] = int.Parse(Application["count"].ToString()) - 1;//在线人数减少一个
Application.UnLock();
}
</script>
麻烦高人帮看下吧
http://topic.csdn.net/t/20060112/01/4511799.html
Session退出时实现人数统计不准确。非法关机或关闭IE不会执行
要记录用户日志和操作时间,再用定时器刷新计算用户
已经有固定时间没有活动的用户,然后删除