亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JS 攔截全局ajax請求實例解析

2019-11-19 18:46:55
字體:
來源:轉載
供稿:網友

你是否有過下面的需求:需要給所有ajax請求添加統一簽名、需要統計某個接口被請求的次數、需要限制http請求的方法必須為get或post、需要分析別人網絡協議等等,那么如何做?想想,如果能夠攔截所有ajax請求,那么問題就會變的很簡單!😄,少年,想法有點大膽,不過,我欣賞!直接上輪子,Ajax-hook不僅可以滿足你想要的,同時可以給你更多。

Ajax-hook源碼地址 : https://github.com/wendux/Ajax-hook

如何使用

1.引入ajaxhook.js

<script src="wendu.ajaxhook.js"></script>

2.攔截需要的ajax 回調或函數。

hookAjax({//攔截回調onreadystatechange:function(xhr){console.log("onreadystatechange called: %O",xhr)},onload:function(xhr){console.log("onload called: %O",xhr)},//攔截函數open:function(arg){console.log("open called: method:%s,url:%s,async:%s",arg[0],arg[1],arg[2])}})

ok, 我們使用jQuery(v3.1) 的get方法來測一下:

// get current page source code $.get().done(function(d){console.log(d.substr(0,30)+"...")})

結果 :

> open called: method:GET,url:http://localhost:63342/Ajax-hook/demo.html,async:true> onload called: XMLHttpRequest> <!DOCTYPE html><html><head l...

攔截成功了! 我們也可以看到jQuery3.1內部已經放棄onreadystatechange而改用onload了。

API

hookAjax(ob)

  • ob,類型是對象,key為想要攔截的回調或函數,value為我們的攔截函數。
  • 返回值: 原始的 XMLHttpRequest。如果有寫請求不想被攔截,可以new 這個。

unHookAjax()

  • 卸載攔截;卸載后,攔截將失效。

改變ajax行為

攔截所有ajax請求,檢測請求method,如果是“GET”,則中斷請求并給出提示

hookAjax({open:function(arg){if(arg[0]=="GET"){console.log("Request was aborted! method must be post! ")return true;}} })

攔截所有ajax請求,請求統一添加時間戳

hookAjax({open:function(arg){arg[1]+="?timestamp="+Date.now();} })

修改請求返回的數據“responseText”

hookAjax({onload:function(xhr){//請求到的數據首部添加"hook!" xhr.responseText="hook!"+xhr.responseText;}})

結果:

hook!<!DOCTYPE html><html><h...

有了這些示例,相信開篇提到的需求都很容易實現。最后測一下unHook

hookAjax({onreadystatechange:function(xhr){console.log("onreadystatechange called: %O",xhr)//return true},onload:function(xhr){console.log("onload called")xhr.responseText="hook"+xhr.responseText;//return true;},open:function(arg){console.log("open called: method:%s,url:%s,async:%s",arg[0],arg[1],arg[2])arg[1]+="?hook_tag=1";},send:function(arg){console.log("send called: %O",arg[0])}})$.get().done(function(d){console.log(d.substr(0,30)+"...")//use original XMLHttpRequestconsole.log("unhook")unHookAjax()$.get().done(function(d){console.log(d.substr(0,10))})})

輸出:

open called: method:GET,url:http://localhost:63342/Ajax-hook/demo.html,async:truesend called: nullonload calledhook<!DOCTYPE html><html><he...unhook<!DOCTYPE

注意

1.攔截函數返回值是一個boolean,如果為true則會阻斷ajax請求,默認為false,不會阻斷請求。

2.所有的回調攔截函數的參數為當前的XMLHttpRequest 實例,如onreadystatechange、onload;所有ajax原始方法的攔截函數會將原始參數以數組的形式傳遞給攔截函數,你可以在攔截函數中修改它。

以上所述是小編給大家介紹的JS 攔截全局ajax請求實例解析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲无线码在线一区观看| 久久久精品国产| 久久视频在线免费观看| 91久久精品国产| 亚洲激情久久久| 国产精品中文久久久久久久| 久久精品国产一区二区三区| 亚洲自拍av在线| 4444欧美成人kkkk| 麻豆国产va免费精品高清在线| 日韩免费在线播放| 欧美中文字幕第一页| 久久中文久久字幕| 国产97人人超碰caoprom| 国产福利精品av综合导导航| 欧美激情精品久久久久久黑人| 精品成人69xx.xyz| 91国在线精品国内播放| 国产精品影片在线观看| 91午夜理伦私人影院| 亚洲一区二区在线播放| 欧美日韩国产成人高清视频| 4k岛国日韩精品**专区| 亚洲国产成人爱av在线播放| 久久精品小视频| 91国产中文字幕| 久久久久久久久久久成人| 亚洲人成亚洲人成在线观看| 亚洲天堂男人天堂| 国产午夜精品全部视频播放| 国产精品福利网| 亚洲免费高清视频| 亚洲欧洲日产国码av系列天堂| 69久久夜色精品国产7777| 精品成人69xx.xyz| 久久精品99国产精品酒店日本| 亚洲福利视频二区| 日韩电影中文字幕一区| 视频在线观看99| 亚洲国产精品久久久久久| 国产欧亚日韩视频| 久久久中文字幕| 亚洲精品xxxx| 国产aaa精品| 日韩欧亚中文在线| 久久精品视频在线| 精品视频在线观看日韩| 91视频国产一区| 亚洲日本中文字幕| 国产精品久久久久久久久久尿| 日韩在线视频免费观看| 久久久久久国产精品美女| 中文字幕精品—区二区| 欧美最猛性xxxxx亚洲精品| 亚洲无av在线中文字幕| 欧美在线播放视频| 亚洲丝袜一区在线| 国产精品白丝jk喷水视频一区| 国产在线拍偷自揄拍精品| 国产精品揄拍500视频| 亚洲欧洲国产精品| 96pao国产成视频永久免费| 欧美午夜精品久久久久久久| 亚洲色图13p| 日韩国产在线看| 亚洲成人av中文字幕| 久热99视频在线观看| 日韩欧美成人网| 成人午夜在线影院| 亚洲一级免费视频| 国产欧美日韩精品专区| 欧美黑人视频一区| 久久九九全国免费精品观看| 久久久亚洲欧洲日产国码aⅴ| 久久久免费精品视频| 精品久久久91| 亚洲国产精品一区二区久| 福利视频导航一区| 91精品国产高清久久久久久久久| 久久久亚洲精品视频| 热久久这里只有精品| 久久手机免费视频| 欧美大尺度激情区在线播放| 亚洲欧美福利视频| 久久精品99国产精品酒店日本| 久久99精品久久久久久噜噜| 亚洲国产天堂久久综合网| 国产日韩欧美日韩大片| 亚洲精品久久久一区二区三区| 91精品国产九九九久久久亚洲| 北条麻妃一区二区在线观看| 欧洲成人免费视频| 久久五月天色综合| 亚洲香蕉在线观看| 国产美女久久精品| 亚洲天堂开心观看| 亚洲一区美女视频在线观看免费| 久久亚洲国产精品成人av秋霞| 亚洲精品一区二区三区婷婷月| 日韩在线视频播放| 亚洲肉体裸体xxxx137| 国外成人在线直播| 精品高清美女精品国产区| 欧美在线www| 国产精品专区第二| 精品国产自在精品国产浪潮| 97av在线视频| 久久精品中文字幕免费mv| 亚洲成人黄色网| 欧美亚洲国产精品| 成人国产精品久久久久久亚洲| 欧美高清不卡在线| 97香蕉超级碰碰久久免费的优势| 亚洲女人天堂网| 久久精品99久久久久久久久| 成人午夜高潮视频| 96精品视频在线| 中文字幕亚洲无线码在线一区| 久久久久久久香蕉网| 久久久精品视频在线观看| 色香阁99久久精品久久久| 亚洲成人黄色在线观看| 亚洲男人天堂2023| 欧美国产日韩一区二区| 久久精品国产精品亚洲| 国产精品视频精品视频| 亚洲精品网址在线观看| 国产午夜精品理论片a级探花| 精品国产乱码久久久久久虫虫漫画| 国内精品久久久久久久久| 久久视频精品在线| 国产日韩欧美电影在线观看| 亚洲四色影视在线观看| 日本高清不卡的在线| 久久视频在线看| 欧美日韩免费网站| 亚洲综合自拍一区| 日韩一级裸体免费视频| 久久躁狠狠躁夜夜爽| 亚洲精品色婷婷福利天堂| 国产精品96久久久久久又黄又硬| 国产精品第七十二页| 欧美精品18videos性欧| 日本成人在线视频网址| 久久这里有精品视频| 欧美成人网在线| 热久久这里只有精品| 亚洲激情第一页| 91亚洲精品久久久久久久久久久久| 欧美日韩国产色| 2018中文字幕一区二区三区| 日韩中文字幕在线精品| 久久久久久久久久久人体| 91超碰caoporn97人人| 精品国内亚洲在观看18黄| 一区二区福利视频| 亚洲一区二区三区久久| 亚洲综合日韩在线| 欧美疯狂性受xxxxx另类| 91精品视频在线| 国产成人精品在线观看| 欧美亚州一区二区三区| 欧美夜福利tv在线| 中文字幕亚洲图片|