ajax调用后台异常,页面跳转

在java开发中,我们往往需要统一处理异常信息,跳转到某一个错误提示页面。

然而,通过ajax调用后台时,后台抛出异常后,页面却没有跳转到异常页面,原因是后台异常时,没有正确向ajax返回信息,

这时,ajax就会走到error处理方法。

这种问题怎么解决呢,下面用代码举例:

失败时,返回页面的jsp为:/view/error/notAuthorize.jsp

ajax代码:

[javascript]  view plain copy
  1. $.ajax({  
  2.      type: "GET",  
  3.      url: "${path}/off/getScheduleJson.action?random=Math.random",  
  4.      data: {day:data},  
  5.      dataType: "json",  
  6.      success: function(data){  
  7.                 success();//成功时的处理方法  
  8.                
  9.               },  
  10.      error: function(data){  
  11.        error(data);//失败时的处理方法  
  12.      }  
  13.  });  

下面主要说失败时的处理方法:

[javascript]  view plain copy
  1. function error(data){  
  2.     var result = data.responseText;  
  3.     if(result !=null && result !=''){//后台异常时,并在后台捕获  
  4.         var url = getRootPath()+"/view/error/notAuthorize.jsp";//获取工程路径  
  5.         location.href = url;  
  6.         //$(document.body).html(result);   
  7.     }else{//后台异常,且没有被捕获  
  8.         clickautohide(5);  
  9.     }  
  10. }  

[javascript]  view plain copy
  1. //js获取项目根路径,如:http://localhost:8099/UniqueduHome  
  2.  function getRootPath(){  
  3.         //获取当前网址,如: http://localhost:8099/UniqueduHome/view/error/notAuthorize.jsp  
  4.         var curWwwPath=window.document.location.href;  
  5.         //获取主机地址之后的目录,如: UniqueduHome/view/error/notAuthorize.jsp  
  6.         var pathName=window.document.location.pathname;  
  7.         var pos=curWwwPath.indexOf(pathName);  
  8.         //获取主机地址,如: http://localhost:8099  
  9.         var localhostPaht=curWwwPath.substring(0,pos);  
  10.         //获取带"/"的项目名,如:/UniqueduHome  
  11.         var projectName=pathName.substring(0,pathName.substr(1).indexOf('/')+1);  
  12.         return(localhostPaht+projectName);  
  13.     }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值