私はWIFでスライドセッションを設定しようとしており、SessionSecurityTokenReceivedを処理する必要があります。Global.asaxでSessionSecurityTokenReceivedイベントを処理するにはどうすればよいですか?
私はここで何かばかげたことをしていると確信しています...しかし、VS2010は、以下に示す場所でThere is no applicable variable or member
ということを教えてくれます。誰かが私を正しい方向に向けることができますか?私は、このイベントの処理を定義する方法の実際のサンプルについて、高値と低値を検索しましたが、1つを見つけることはできません。
Global.asaxの
protected void Application_Start()
{
FederatedAuthentication.WSFederationAuthenticationModule.SecurityTokenReceived
+= SessionAuthenticationModule_SessionSecurityTokenReceived;
// ^^^ There is no applicable variable or member
}
void SessionAuthenticationModule_SessionSecurityTokenReceived(object sender, SessionSecurityTokenReceivedEventArgs e)
{
DateTime now = DateTime.UtcNow;
DateTime validFrom = e.SessionToken.ValidFrom;
DateTime validTo = e.SessionToken.ValidTo;
if ((now < validTo) &&
(now > validFrom.AddMinutes((validTo.Minute - validFrom.Minute)/2))
)
{
SessionAuthenticationModule sam = sender as SessionAuthenticationModule;
e.SessionToken = sam.CreateSessionSecurityToken(
e.SessionToken.ClaimsPrincipal,
e.SessionToken.Context,
now,
now.AddMinutes(2),
e.SessionToken.IsPersistent);
e.ReissueCookie = true;
}
else
{
//todo: WSFederationHelper.Instance.PassiveSignOutWhenExpired(e.SessionToken, this.Request.Url);
// this code from: http://stackoverflow.com/questions/5821351/how-to-set-sliding-expiration-in-my-mvc-app-that-uses-sts-wif-for-authenticati
var sessionAuthenticationModule = (SessionAuthenticationModule)sender;
sessionAuthenticationModule.DeleteSessionTokenCookie();
e.Cancel = true;
}
}
簡単で魅力的です!配線が必要なイベントとそうでないイベントの違いを教えてください – LamonteCristo