本文實例講述了asp.net簡單實現單點登錄(SSO)的方法。分享給大家供大家參考,具體如下:
單點登錄(Single Sign On , 簡稱 SSO )是目前比較流行的服務于企業業務整合的解決方案之一, SSO 使得在多個應用系統中,用戶只需要登錄一次就可以訪問所有相互信任的應用系統
CAS(Central Authentication Service)是一款不錯的針對 Web 應用的單點登錄框架(耶魯大學開發)主要用于Java Php 有興趣大家可以研究下..
下面是一個簡單實現單點登錄的方法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
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 配置 窗體模式
1
2
3
4
5
6
7
|
< authentication mode = "Forms" >//mode值是Forms為定義成窗體驗證 < forms loginUrl = "Mananger/Login.aspx" name = ".ASPXAUTH" >//用戶未登陸就先訪問Mananger/Login.aspx頁面 </ forms > </ authentication > < authorization > < deny users = "?" /> </ authorization > |
希望本文所述對大家asp.net程序設計有所幫助。