我想实现一个Web应用程序项目在我的网页,可以检查服务器使用AJAX的身份验证票证过期日期/时间。
我使用窗体身份验证与slidingExpiration。
我碰到运行的问题是我无法弄清楚如何在不重新检查它的价值。 我创建了一个简单的页面 - CheckExpiration.aspx - 以下是后面的代码:
private class AjaxResponse
{
public bool success;
public string message;
public string expirationDateTime;
public string secondsRemaining;
public string issueDate;
}
protected void Page_Load(object sender, EventArgs e)
{
AjaxResponse ar = new AjaxResponse();
JavaScriptSerializer js = new JavaScriptSerializer();
if (HttpContext.Current.User.Identity.IsAuthenticated)
{
FormsIdentity id = (FormsIdentity)HttpContext.Current.User.Identity;
string expiration = id.Ticket.Expiration.ToString();
TimeSpan timeRemaining = id.Ticket.Expiration - DateTime.Now;
ar.success = true;
ar.expirationDateTime = expiration;
ar.issueDate = id.Ticket.IssueDate.ToString();
ar.secondsRemaining = timeRemaining.Minutes.ToString() + ":" + timeRemaining.Seconds.ToString();
}
else
{
ar.success = false;
ar.message = "User not authenticated";
}
string output = js.Serialize(ar);
Response.Write(js.Serialize(ar));
}
我用ajax每秒调用从母版页此页面中我的申请。 过去在认证到期的中间点,过期被重置。
如何防止这种行为? 有什么我可以在可能的请求的头呢?