我使用表单身份验证相当成功,但遇到了一个奇怪的问题。 我在网上翻了翻,到目前为止还没有找到答案。
我正在使用一些 Javascript 来确定当前会话何时距离超时还有 60 秒,如果是这样 - 弹出一个带有按钮的对话框,如果按下该按钮,将扩展当前的 FormsAuthentication 票证。
这是我用来续订票证的代码。 我只是在票证的当前到期日期上增加 5 分钟。 但是当我输出新的到期日期时,它总是不到 5 分钟;通常为4分零几秒钟。
代码:
string userID = HttpContext.Current.User.Identity.Name;
HttpCookie cookie = FormsAuthentication.GetAuthCookie(userID, true);
FormsAuthenticationTicket ticket = FormsAuthentication.Decrypt(cookie.Value);
DateTime NEW_EXPIRY = DateTime.Now.AddMinutes(FormsAuthentication.Timeout.Minutes);
FormsAuthenticationTicket newTicket = new FormsAuthenticationTicket(
ticket.Version,
userID,
DateTime.Now,
NEW_EXPIRY,
ticket.IsPersistent,
ticket.UserData,
ticket.CookiePath);
cookie.Value = FormsAuthentication.Encrypt(newTicket);
if (ticket.IsPersistent) cookie.Expires = newTicket.Expiration;
cookie.Secure = FormsAuthentication.RequireSSL;
HttpContext.Current.Response.Cookies.Add(cookie);
因此,下面是时差的示例输出:
现在的时间戳 = 16/01/2016 14:03:28 票证过期=16/01/2016 14:07:49(总秒数=261.0857244)
为什么它没有将到期时间重置为正好 14:08:28?我在这里用头撞墙...
所以我仍然不知道为什么 FormsIdentity 对象的过期值不正确......所以我所做的是从续订方法传回实际的新过期值(作为日期时间),并依赖于它。 因此,这个值似乎是正确的,这就是我应该用来确定实际超时值的值。
这甚至有意义吗? 我不知道,但它现在正在工作!