asp.net简单实现单点登录(SSO)的方法
本文实例讲述了asp.net简单实现单点登录(SSO)的方法。分享给大家供大家参考,具体如下:
单点登录(SingleSignOn,简称SSO)是目前比较流行的服务于企业业务整合的解决方案之一,SSO使得在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统
CAS(CentralAuthenticationService)是一款不错的针对Web应用的单点登录框架(耶鲁大学开发)主要用于JavaPhp有兴趣大家可以研究下..
下面是一个简单实现单点登录的方法:
publicvoidSingleUserLogin(stringuserName){
//定义键值
stringkey=userName;
stringvalue=Convert.ToString(Cache[key]);
if(value==null||value==string.Empty){
//定义Cache过期时间
TimeSpanspan=newTimeSpan(0,0,HttpContext.Current.Session.Timeout,0,0);
//第一次登陆的时候插入一个用户相关的cache值,
HttpContext.Current.Cache.Insert(key,key,null,DateTime.MaxValue,span,System.Web.Caching.CacheItemPriority.NotRemovable,null);
Session["userName"]=userName;
Response.Redirect("Main.aspx");
}
elseif(Cache[key].ToString()==key){
//重复登陆
Response.Write("<mce:scripttype="text/javascript"><!--
alert('您的账号已经登陆!');window.location='login.aspx';
//--></mce:script>");
}
else{
//取消当前的session会话
Session.Abandon();
}
}
在WebConfig配置窗体模式
<authenticationmode="Forms">//mode值是Forms为定义成窗体验证 <formsloginUrl="Mananger/Login.aspx"name=".ASPXAUTH">//用户未登陆就先访问Mananger/Login.aspx页面 </forms> </authentication> <authorization> <denyusers="?"/> </authorization>
希望本文所述对大家asp.net程序设计有所帮助。