c# – 在ASP.NET中限制每个用户只有一个会话

前端之家收集整理的这篇文章主要介绍了c# – 在ASP.NET中限制每个用户只有一个会话前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
是否有任何检测用户登录时是否已经有另一个会话使用相同的用户名,并阻止他再次登录或向他发送消息?

解决方法

您可以随时在global.asax中实现事件.

实现Application_Start()来设置System.Collections.Dictionary(或根据您的偏好),并将其存储在Application []集合中,当用户登录时,添加用户名.从Session_End()中的集合中删除.记住在使用集合时使用’lock’关键字:)

玩的开心!

例:

[page.aspx]
public partial class page : System.Web.UI.Page {
    protected bool Login(string userName) {
        System.Collections.Generic.List<string> d = Application["UsersLoggedIn"]
            as System.Collections.Generic.List<string>;
        if (d != null) {
            lock (d) {
                if (d.Contains(userName)) {
                    // User is already logged in!!!
                    return false;
                }
                d.Add(userName);
            }
        }
        Session["UserLoggedIn"] = userName;
        return true;
    }

    protected void logout() {
        Session.Abandon();
    }
}

[global.asax]
<%@ Application Language="C#" %>
<script RunAt="server">
    void Application_Start(object sender,EventArgs e) {
        Application["UsersLoggedIn"] = new System.Collections.Generic.List<string>();
    }

    void Session_End(object sender,EventArgs e) {
        // NOTE: you might want to call this from the .logout() method - aswell -,to speed things up
        string userLoggedIn = Session["UserLoggedIn"] == null ? string.Empty ? (string)Session["UserLoggedIn"];
        if (userLoggedIn.Length > 0) {
            System.Collections.Generic.List<string> d = Application["UsersLoggedIn"] 
                as System.Collections.Generic.List<string>;
            if (d != null) {
                lock (d) {
                    d.Remove(userLoggedIn);
                }
            }
        }
    }
</script>

猜你在找的C#相关文章