当前位置:首页>开发>正文

如何拦截或修改原生ajax请求 UIWebView怎么拦截Ajax请求

2023-05-09 08:49:52 互联网 未知 开发

 如何拦截或修改原生ajax请求 UIWebView怎么拦截Ajax请求

如何拦截或修改原生ajax请求

function(conn,设置response.sendError(408)在struts.xml中写全局/login.jsp 在jsp页面中写Ext.Ajax.on("requestexception"如果未登录或者没有操作权限就自动跳转到登陆界面。也配置了全局的跳转。 在拦截器里判断请求类型,判断是普通请求还是ajax请求.location="login.jsp".status==408){window,response,options){if(response

UIWebView怎么拦截Ajax请求

app中所有网络请求都可以通过NSURLProtocol来拦截处理,如:
1、利用html5的cache机制(但是网页cache有大小限制);
2、利用对html5做自定义解析,对dom树分析后请求并存储相关资源;
3、利用NSURLCache(写存储,写一二级缓存效率高,空间无限制);
4、利用NSURLProtocol完成缓存工作。

javascript 发送ajax请求阻塞问题

主要有两个可能出问题的地方:1.ajax请求是同步的(open方法的参数中,可以设置)
2.ajax请求的服务器端asp页面可能使用了session,导致页面被锁死。关闭ajax所请求的页面的session(是ajax请求的页面,不是ajax所在的页面)

如何防止ajax请求的参数被拦截修改

jquery ajax是个很常用接口,而在请求时候,可能存在响应401的情况(身份认证过期或未登录),比较容易出现在混合应用上,如何进行身份认证,重发失败请求,还是值得注意的。

ajax请求有两种方式

1. 回调

最常写的方式,成功失败处理以回调方式传入。
$.ajax({ ajax参数... success : xxxxxx error: xxxxxx })
2. Deferred方式

Deferred模式我在《js异步编程》有说明, ajax调用本身返回就是一个Deferred对象,成功失败回调不以参数传入。
$.ajax({ ajax参数... }).then(function(res){ //成功处理片段 },function(err){ //失败处理片段 })
既然有这两种方式,那应对处理401的方式也是有两种。

401处理的两种方式

1. 回调

这种方式的处理比较简单,在失败回调里面判断401,如果是则进行身份认证,成功重发请求。
function getXXXX(type, url, data, success, error){   $.ajax({   ajax参数...    success : xxxxxx    error : function(xhr,textStatus,errorThrown){   if (xhr.status == 401) {      刷新身份认证方法(function(){   getXXXX(type, url, data, success, error)   })  } else{   // 调用外部的error   error && error(xhr,textStatus,errorThrown)    }   }   }) }
2. Deferred方式

这种方式目前我找到的处理方式需要修改jquery源码。
//全局设置一个方法 $.ajaxSetup({ authError : function(callback){ 刷新身份认证方法( function(){ callback && callback() }) } }) //jquery2.1.4版本源码,大概是8261行 // Success/Error if ( isSuccess ) { deferred.resolveWith( callbackContext, [ success, statusText, jqXHR ] ) } else { if(( jqXHR.status == 401 || jqXHR .status == 403) && callbackContext.authError){   callbackContext.authError(function (){ state = 0 jqXHR.setRequestHeader( "Authorization", XXXXXX) jqXHR.readyState = 1 try { state = 1 transport.send( requestHeaders, done ) } catch ( e ) { // Propagate exception as error if not done if ( state < 2 ) { done( -1, e ) // Simply rethrow otherwise } else { throw e } }   })   return } else { deferred.rejectWith( callbackContext, [ jqXHR, statusText, error ] ) } }
这里说下为什么不能像第一种方式那样进行请求。

有两个原因:

1. then这种链式写法,导致这请求的回调不是在参数里,而是在jQuery.Callbacks一个optionsCache全局变量里,我们无法在ajax error里拿到回调函数进行重发。

2. 写在then里的回调触发一次就会被销毁,当触发了error时,回调执行后就销毁。

最后的处理方式就是在要触发error之前,拦截401的错误,重新进行身份认证,然后重置状态,重发请求。

以上这篇当jquery ajax遇上401请求的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

java interceptor ajax请求能拦截吗

//获取判定登陆的session是否存在
String token = (String) request.getSession().getAttribute("token")
String postId = (String) request.getSession().getAttribute("postId")
if(token == null || token == ""){
String XRequested =request.getHeader("X-Requested-With")
if("XMLHttpRequest".equals(XRequested)){
response.getWriter().write("IsAjax")
}else{
response.sendRedirect("/m-web/user/toLogin")
}
return false
}
if(postId == null || postId == ""){
String XRequested =request.getHeader("X-Requested-With")
if("XMLHttpRequest".equals(XRequested)){
response.getWriter().write("IsAjax")
}else{

最新文章