获取当前访问的页面的名字(如 WebForm1.aspx)

  private void Page_Load(object sender, System.EventArgs e)
  {
   Label1.Text=GetCtrlNamePath();   
  }
 protected string GetCtrlNamePath()
  {
   string s  =GetType().ToString();    //ASP.Control_JBRFH_ascx
   s = s.Substring(4,s.Length -4);
   int i =s.LastIndexOf("_");
   string  typeName = s.Substring(0,i)+"."+s.Substring(i+1,s.Length - i  - 1);
   return typeName;
  }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
当用户关闭浏览器时,无法直接触发服务器端的代码来移除用户信息。但是我们可以利用 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)来存储用户信息。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值