C# WebForm的Global.asax文件

Global.asax文件是可选的,只有希望在程序的生命周期做某些操作才需要创建


public class Global : System.Web.HttpApplication { /// Web应用程序第一次启动时调用该方法,并且该方法只被调用一次(就是部署到IIS上之后第一次启动这个程序的时候调用一次)。 protected void Application_Start(object sender, EventArgs e) { } /// 开始会话。(用户通过浏览器第一次访问我们网站中的某个页面,这时建立会话,但是当该用户通过浏览器再次访问其它的页面时,该方法不会被执行) /// (应用场景:统计网站在线人数,注意点就是,一定要把Application写到数据库) protected void Session_Start(object sender, EventArgs e) { // Application:服务端的状态保持机制。放在该对象中的数据是共享的,这点跟Cache一样,但是Application是要程序员手动加锁解锁,但是Cache不一样,内部微软都自动加锁解锁 Application.Lock(); int count = Convert.ToInt32(Application["count"]); count++; Application["count"] = count; Application.UnLock(); } protected void Application_BeginRequest(object sender, EventArgs e) { } protected void Application_AuthenticateRequest(object sender, EventArgs e) { } /// 全局的异常捕捉,在MVC中我们经常都是写一个BaseController,然后每个控制器都继承这个BaseController,然后都统一在BaseController这个控制器里面完成捕捉错误,然后写到log4net这个第三方框架上。但是在WebForm里面,我们要捕捉错误就在这个方法完成 protected void Application_Error(object sender, EventArgs e) { //1.0通过下面这个方法捕捉到错误 //Exception ex = HttpContext.Current.Server.GetLastError(); //2.0下面就跟MVC一样,把错误ex.Message写到Log4Net上 } /// 会话结束(应用场景:统计网站在线人数,注意点就是,一定要把Application写到数据库) protected void Session_End(object sender, EventArgs e) { Application.Lock(); int count = Convert.ToInt32(Application["count"]); count--; Application["count"] = count; Application.UnLock(); } protected void Application_End(object sender, EventArgs e) { } }

  

转载于:https://www.cnblogs.com/BOSET/p/7074762.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当用户关闭浏览器时,无法直接触发服务器端的代码来移除用户信息。但是我们可以利用 Session 的过期时间来间接达到用户退出的效果。 首先,在用户登录成功后,将用户信息存储到 Dictionary 中,并将该用户的 Session ID 作为键。然后,通过将该键值对存储到 Session 中,以便在后续的请求中进行验证。 在 WebForm2.aspx 的 Page_Load 方法中,判断 Session 是否存在该键,如果存在,则表示用户已登录。如果不存在,则表示用户未登录或已退出,可以执行相关操作。 下面是一个简单的示例代码: ```csharp // WebForm2.aspx.cs protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { if (Session["LoggedInUser"] != null) { // 用户已登录 string sessionId = Session.SessionID; Dictionary<string, string> userDictionary = (Dictionary<string, string>)Application["UserDictionary"]; if (userDictionary.ContainsKey(sessionId)) { // 执行退出登录操作 string username = userDictionary[sessionId]; userDictionary.Remove(sessionId); // 其他清理操作... // 重定向到登录页面或其他页面 Response.Redirect("WebForm1.aspx"); } } } } ``` 在登录成功的地方,将用户信息存储到 Dictionary 和 Session 中: ```csharp // 登录成功后的代码 string username = "用户名"; // 将实际的用户名替换为登录时获取的用户名 string sessionId = Session.SessionID; Dictionary<string, string> userDictionary = (Dictionary<string, string>)Application["UserDictionary"]; // 将用户信息存储到 Dictionary 中 userDictionary[sessionId] = username; // 将键值对存储到 Session 中,以便在后续的请求中进行验证 Session["LoggedInUser"] = username; // 其他处理... // 重定向到需要跳转的页面 Response.Redirect("WebForm1.aspx"); ``` 请注意,上述代码仅为示例,实际应用中可能需要进行更多的错误处理和安全验证。另外,为了在多个用户同时访问时保持数据的一致性,可能需要考虑使用线程安全的集合(如 ConcurrentDictionary)来存储用户信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值