当前位置:Gxlcms > JavaScript > javascript写一个ajax自动拦截并下载数据代码实例

javascript写一个ajax自动拦截并下载数据代码实例

时间:2021-07-01 10:21:17 帮助过:37人阅读

这篇文章主要介绍了javascript写一个ajax自动拦截并下载数据代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

代码如下

  1. <!DOCTYPE html>
  2. <html lang="zh">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  7. <title></title>
  8. </head>
  9. <body>
  10. </body>
  11. <script type="text/javascript" src="js/jquery-3.3.1.min.js"></script>
  12. <script type="text/javascript">
  13. // 自动下载 ajax 的脚本
  14. ;(function($,flag,host){
  15. if(!flag){
  16. //如果关闭下载数据,则什么也不做,否则会拦截 ajax 请求返回的数据,进行下载
  17. return ;
  18. }
  19. var ajax = $.ajax; //缓存原始的 ajax
  20. $.ajax = function(opt){
  21. var success = opt.success || function(){};
  22. var url = opt.url || "";
  23. opt.success = function(res){
  24. try{
  25. var name = url.split("?")[0];
  26. if(host){
  27. name = name.replace(host,"");
  28. }
  29. name = name.replace(/\//g,"_");
  30. downData(res,`${name}.json`);
  31. }catch(e){
  32. console.warn(e);
  33. }
  34. success(res);
  35. }
  36. return ajax(opt);
  37. }
  38. function downData(data,name){
  39. if(typeof data == "object"){
  40. data = JSON.stringify(data);
  41. }
  42. var blob = new Blob([data], {
  43. type: 'text/html,charset=UTF-8'
  44. });
  45. window.URL = window.URL || window.webkitURL;
  46. var a = document.createElement("a");
  47. a.setAttribute("download",name || "data.json");
  48. a.href = URL.createObjectURL(blob);
  49. a.click();
  50. }
  51. })($,true,"https://www.easy-mock.com");
  52. //自动下载数据
  53. $.ajax({
  54. url:"https://www.easy-mock.com/mock/5bb02bc0a0afc503f502a292/example/demo/secret",
  55. success(res){
  56. console.log(res);
  57. }
  58. })
  59. </script>
  60. </html>

使用原生的 xhr 和fetch 拦截

  1. // 自动下载 ajax 的脚本
  2. // 命名空间
  3. window.ajax_interceptor_manny = {
  4. settings: {
  5. switchOn: false,
  6. switchQuery:false
  7. },
  8. originalXHR: window.XMLHttpRequest,
  9. myXHR: function() {
  10. console.log(" ---ajax 拦截--- ")
  11. let pageScriptEventDispatched = false;
  12. const modifyResponse = () => {
  13. //this.responseText = overrideTxt;
  14. //this.response = overrideTxt;
  15. if (pageScriptEventDispatched) {
  16. return;
  17. }
  18. pageScriptEventDispatched = true;
  19. ajax_interceptor_manny.download(this.responseText, this.responseURL);
  20. }
  21. // new 一个原生的 XMLHttpRequest 不需要参数,将 xhr 的属性,都复制给this,暴露到外面
  22. const xhr = new ajax_interceptor_manny.originalXHR();
  23. for (let attr in xhr) {
  24. if (attr === 'onreadystatechange') {
  25. xhr.onreadystatechange = (...args) => {
  26. if (this.readyState == 4 && this.status == 200) {
  27. // 请求成功
  28. if (ajax_interceptor_manny.settings.switchOn) {
  29. // 开启拦截
  30. modifyResponse();
  31. }
  32. }
  33. this.onreadystatechange && this.onreadystatechange.apply(this, args);
  34. }
  35. continue;
  36. } else if (attr === 'onload') {
  37. xhr.onload = (...args) => {
  38. // 请求成功
  39. if (ajax_interceptor_manny.settings.switchOn) {
  40. // 开启拦截
  41. modifyResponse();
  42. }
  43. this.onload && this.onload.apply(this, args);
  44. }
  45. continue;
  46. }
  47. if (typeof xhr[attr] === 'function') {
  48. this[attr] = xhr[attr].bind(xhr);
  49. } else {
  50. if (attr === 'responseText' || attr === 'response') {
  51. var k = "_"+attr;
  52. Object.defineProperty(this, attr, {
  53. get: () => this[k] == undefined ? xhr[attr] : this[k],
  54. set: (val) => this[k] = val,
  55. });
  56. } else {
  57. Object.defineProperty(this, attr, {
  58. get: () => xhr[attr],
  59. set: (val) => xhr[attr] = val,
  60. });
  61. }
  62. }
  63. }
  64. },
  65. originalFetch: window.fetch.bind(window),
  66. myFetch: function(...args) {
  67. console.log(" ---fetch 拦截--- ")
  68. return ajax_interceptor_manny.originalFetch(...args).then((response) => {
  69. if (response.ok) {
  70. response.clone().text().then((res) => {
  71. ajax_interceptor_manny.download(res, response.url);
  72. }).catch((e) => {
  73. console.warn(e)
  74. });
  75. }
  76. return response;
  77. });
  78. },
  79. download(data, url) {
  80. try {
  81. if (ajax_interceptor_manny.settings.switchOn) {
  82. if (typeof data == "object") {
  83. data = JSON.stringify(data);
  84. }
  85. var blob = new Blob([data], {
  86. type: 'text/html,charset=UTF-8'
  87. });
  88. window.URL = window.URL || window.webkitURL;
  89. var name = url;
  90. if(!(url.indexOf("http://") >= 0 || url.indexOf("https://") >= 0)){
  91. //不存在域名
  92. url = window.origin + url; //手动添加一个,避免URL解析出错
  93. }
  94. try {
  95. var u = new URL(url);
  96. name = u.pathname;
  97. var search = u.search.replace("?","");
  98. if(ajax_interceptor_manny.settings.switchQuery && search){
  99. //需要带上 get 参数
  100. name = name + "$"+ search;
  101. }
  102. } catch (e) {console.warn(e)}
  103. name = name.replace(new RegExp("//","g"),"/");
  104. name = name.replace(new RegExp("/","g"), "_");
  105. name = name + ".json";
  106. var a = document.createElement("a");
  107. a.setAttribute("download", name || "data.json");
  108. a.href = URL.createObjectURL(blob);
  109. a.click();
  110. }
  111. } catch (e) {
  112. console.error("下载数据失败", e);
  113. }
  114. },
  115. setSetting(data) {
  116. if (typeof data !== "object") {
  117. return;
  118. }
  119. //设置环境
  120. for (var i in data) {
  121. ajax_interceptor_manny.settings[i] = data[i];
  122. }
  123. },
  124. init() {
  125. window.XMLHttpRequest = ajax_interceptor_manny.myXHR;
  126. window.fetch = ajax_interceptor_manny.myFetch;
  127. }
  128. }
  129. ajax_interceptor_manny.init();
  130. ajax_interceptor_manny.setSetting({
  131. switchOn:true
  132. })

还可以将这个拦截,写为一个浏览插件:

插件代码地址: https://gitee.com/muand/ajaxDown/tree/master/ajaxDown

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

人气教程排行