本文實例講述了asp.net簡單實現單點登錄(SSO)的方法。分享給大家供大家參考,具體如下:
單點登錄(Single Sign On , 簡稱 SSO )是目前比較流行的服務於企業業務整合的解決方案之一, SSO 使得在多個應用系統中,用戶只需要登錄一次就可以訪問所有相互信任的應用系統
CAS(Central Authentication Service)是一款不錯的針對 Web 應用的單點登錄框架(耶魯大學開發)主要用於Java Php 有興趣大家可以研究下..
下面是一個簡單實現單點登錄的方法:
public void SingleUserLogin(string userName){
//定義鍵值
string key=userName;
string value=Convert.ToString(Cache[key]);
if(value==null||value==string.Empty){
//定義Cache過期時間
TimeSpan span=new TimeSpan(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");
}
else if(Cache[key].ToString()==key){
//重復登陸
Response.Write("<mce:script type="text/javascript"><!--
alert('您的賬號已經登陸!');window.location='login.aspx';
// --></mce:script>");
}
else{
//取消當前的session會話
Session.Abandon();
}
}
在Web Config 配置 窗體模式
<authentication mode="Forms">//mode值是Forms為定義成窗體驗證 <forms loginUrl="Mananger/Login.aspx" name=".ASPXAUTH">//用戶未登陸就先訪問Mananger/Login.aspx頁面 </forms> </authentication> <authorization> <deny users="?"/> </authorization>
希望本文所述對大家asp.net程序設計有所幫助。