c# – ajax调用的会话超时

前端之家收集整理的这篇文章主要介绍了c# – ajax调用的会话超时前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我知道这是重复的,但我无法获得可靠的解决方案(对于asp.net网页).

如果会话到期,我只想重定向登录页面.
我试过以下:

1.使用jquery状态码

  1. $.ajax({
  2. type: "POST",url: "stream.asmx/SomeMethod",contentType: "application/json; charset=utf-8",dataType: "json",success: function (msg) {
  3. //success msg
  4. },error: function (request,status,error) {
  5. if (status = 403) {
  6. location.href = 'login.aspx';
  7. }
  8. }
  9. });

问题:这返回与其他错误相同的状态代码(403),我只期望会话超时.

发送json消息会话是否过期

代码背后:

  1. if (!object.Equals(HttpContext.Current.Session["User"],null))
  2. {
  3. Id = int.Parse(HttpContext.Current.Session["User"].ToString());
  4. }
  5. else
  6. {
  7. result = from row in dtscrab.AsEnumerable()
  8. select new
  9. {
  10. redirectUrl = "login.aspx",isRedirect = true
  11. };
  12. }

在$.ajax成功:

  1. success: function (msg) {
  2. if (msg.d[0].isRedirect) {
  3. window.location.href = msg.d[0].redirectUrl;
  4. }
  5. else {
  6. //load containt
  7. }
  8. }

问题:如果会话过期,它将不会调用ajax成功行(它返回正确的json).即使这不是一个正确的方式,如果我有很多数量的ajax请求在页面(应该在全球处理).

然而,我看到这个帖子是非常好的解决方案,但它是使用AuthorizeAttribute:handling-session-timeout-in-ajax-calls的mvc

那么,我可以在asp.net web api中使用AuthorizeAttribute在mvc中使用相同的概念吗?如果没有,我可以如何解决我面临的问题(上述两个之一)?

解决方法

403状态代码将导致jQuery调用失败方法.从第二次尝试中保留相同的代码,但将重定向处理程序移动到失败方法而不是成功方法.在成功的方法,按照通常的方式对待它.

猜你在找的C#相关文章