1

ブラウザー セッション間で Cookie が保持されないという問題があります。ブラウザを閉じて再度開くと、次のリクエストで Cookie がサーバーに渡されません。

これは、ユーザーがサインインしたときに Cookie を作成する方法です。

var ticket = new FormsAuthenticationTicket(
    1 /*version*/,
    user.Id,
    now,
    now.Add(ExpirationTimeSpan), /* ExpirationTimeSpan = TimeSpan.FromHours(6) */
    true /*createPersistentCookie*/,
    userData,
    FormsAuthentication.FormsCookiePath);

var encryptedTicket = FormsAuthentication.Encrypt(ticket);

var cookie = new HttpCookie(FormsAuthentication.FormsCookieName, encryptedTicket)
                    {
                        HttpOnly = true,
                        Secure = FormsAuthentication.RequireSSL,
                        Path = FormsAuthentication.FormsCookiePath
                    };
if (FormsAuthentication.CookieDomain != null)
{
    cookie.Domain = FormsAuthentication.CookieDomain;
}

var httpContext = this.contextAccessor.Current();
httpContext.Response.Cookies.Add(cookie);

私は何を間違っていますか?

4

1 に答える 1

0

HttpCookie の有効期限をそのように設定する必要があると思います....

var cookie = new HttpCookie(FormsAuthentication.FormsCookieName, encryptedTicket)
        {
            HttpOnly = true,
            Secure = FormsAuthentication.RequireSSL,
            Path = FormsAuthentication.FormsCookiePath,
            Expires=  = DateTime.UtcNow.AddHours(6);
        };
于 2012-05-31T20:45:47.310 に答える