本文實例講述了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程序設計有所幫助。