111,037
社区成员
发帖
与我相关
我的任务
分享
void Application_Start(object sender, EventArgs e)
{
// 在应用程序启动时运行的代码
//定义菜单对象
System.Data.DataTable _myMenu=null;
System.Collections.ArrayList _onlineUser = new ArrayList();
_onlineUser.Clear();
}
页面:
//存用户ID到全局变量_onlineUser中去
((ArrayList)Application["_onlineUser"]).Add("gm");
void Application_Start(object sender, EventArgs e)
{
// 在应用程序启动时运行的代码
//定义菜单对象
System.Data.DataTable _myMenu=null;
System.Collections.ArrayList _onlineUser = null;
}
Session["userName"] = this.TxtB_UserName.Text.Trim();
//存用户ID到全局变量_onlineUser中去
Application.Lock();
if (Application["_onlineUser"] == null)
{
ArrayList _myUser = new ArrayList();
_myUser.Add(Session["userName"]);
Application["_onlineUser"] = _myUser;
}
else
{
//判断用户是否存在,不存在则添加到全局变量 Application["_onlineUser"] 中去
if (!((ArrayList)Application["_onlineUser"]).Contains(Session["userName"]))
{
((ArrayList)Application["_onlineUser"]).Add(Session["userName"]);
}
else { Response.Write("<script>alert('该用户已登陆,您无法登陆!');</script>"); }
}
Application.UnLock();
//显示一下当前在线用户(即Application["_onlineUser"]的所有内容)
for (int i = 0; i < ((ArrayList)Application["_onlineUser"]).Count; i++)
{
Response.Write("<script>alert('" + ((ArrayList)Application["_onlineUser"])[i].ToString() + "');</script>");
}
void Session_End(object sender, EventArgs e)
{
// 在会话结束时运行的代码。
// 注意: 只有在 Web.config 文件中的 sessionstate 模式设置为
// InProc 时,才会引发 Session_End 事件。如果会话模式设置为 StateServer
// 或 SQLServer,则不会引发该事件。
Application.Lock();
try
{
//把用户从全局变量 _onlineUser 中删除
((ArrayList)Application["_onlineUser"]).Remove(Session["userName"]);
}
catch (Exception ex)
{ }
Application.UnLock();
}
//试试
void Application_Start(object sender, EventArgs e)
{
// 在应用程序启动时运行的代码
//定义菜单对象
System.Data.DataTable _myMenu=null;
System.Collections.ArrayList _onlineUser = new ArrayList();
_onlineUser.Clear();
}
页面:
//存用户ID到全局变量_onlineUser中去
ArrayList arr = Application["_onlineUser"] as ArrayList;
if(arr.Count < 1)
{
arr.Add("gm");
}
else if(!arr.Contains("gm"))
{
arr.Add("gm");
}
Application["_onlineUser"]) = arr;