·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> 网站建设开发 >> ASP.NET网站开发 >> ASP.NET单点登录(代码)

ASP.NET单点登录(代码)

作者:佚名      ASP.NET网站开发编辑:admin      更新时间:2022-07-23

asp.net单点登录(代码)

由于某些原因,在我们的应用中会遇到一个用户只能在一个地方登录的情况,也就是我们通常所说的单点登录。在ASP.NET中实现单点登录其实很简单,下面就把主要的方法和全部代码进行分析。

实现思路

利用Cache的功能,我们把用户的登录信息保存在Cache中,并设置过期时间为session失效的时间,因此,一旦Session失效,我们的Cache也过期;而Cache对所有的用户都可以访问,因此,用它保存用户信息比数据库来得方便。

string sKey = username.Text.ToString().Trim(); // 得到Cache中的给定Key的值            string sUser = Convert.ToString(Cache[sKey]); // 检查是否存在             if (sUser == null || sUser == String.Empty)            {                                TimeSpan SessTimeOut = new TimeSpan(0, 0, System.Web.HttpContext.Current.Session.Timeout, 0, 0);//取得Session的过期时间                HttpContext.Current.Cache.Insert(sKey, sKey, null, DateTime.MaxValue, SessTimeOut, System.Web.Caching.CacheItemPRiority.NotRemovable, null);//将值放入cache己方便单点登录              //成功登录            }            else if (Cache[sKey].ToString() == sKey)//如果这个账号已经登录            {                ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('对不起,当前用户已经登录');</script>");                return;            }            else            {                Session.Abandon();//这段主要是为了避免不必要的错误导致不能登录            }