標籤:insert gis name 思路 bsp 原因 http 錯誤 type
由於某些原因,在我們的應用中會遇到一個使用者只能在一個地方登入的情況,也就是我們通常所說的單點登入。在ASP.NET中實現單點登入其實很簡單,下面就把主要的方法和全部代碼進行分析。[/p][p=25, null, left]實現思路[/p][p=25, null, left]利用Cache的功能,我們把使用者的登入資訊儲存在Cache中,並設定到期時間為Session失效的時間,因此,一旦Session失效,我們的Cache也到期;而Cache對所有的使用者都可以訪問,因此,用它儲存使用者資訊比資料庫來得方便。[/p]
[p=25, null, left]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();//這段主要是為了避免不必要的錯誤導致不能登入
}
ASP.NET單點登入(代碼)