成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

關于Ajax跨域問題及解決方案詳析

瀏覽:650日期:2022-06-11 10:24:43

復現Ajax跨域問題

做兩個簡單的小項目復現Ajax跨域問題. 后端語言使用Java

首先是一個簡單的訂單系統, 通過訪問/loadOrderList, 最終以json串形式返回訂單集合. 該項目使用Tomcat發布在7070端口.

@RequestMapping("/loadOrderList")@ResponseBodypublic List<Order> loadOrderList(String uid){ //模擬訂單數據 Order o1 = new Order(); o1.setId("111"); o1.setTotal(333.33); o1.setDate("2019-4-29"); Order o2 = new Order(); o2.setId("222"); o2.setTotal(444.44); o2.setDate("2019-5-29"); Order o3 = new Order(); o3.setId("333"); o3.setTotal(555.55); o3.setDate("2019-6-29"); List<Order> list = new ArrayList<>(); list.add(o1); list.add(o2); list.add(o3); return list;}

在另一個項目中做一個向訂單系統發送一個ajax請求, 獲取訂單集合. 該項目使用Tomcat插件發布在9090端口.

//index.jsp<%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head> <title>Title</title> <script type="text/javascript" src="https://code.xxx.com/jquery-1.11.3.js"></script> <script type="text/javascript"> function sendAjax() {  $.post("http://localhost:7070/order/loadOrderList", "uid=1234", function (data) {  alert(data);  }); } </script></head><body> <a href="javascript:sendAjax()" rel="external nofollow" rel="external nofollow" >sendAjax</a></body></html>

點擊sendAjax超鏈接向訂單系統發送ajax請求.

通過開發者工具發現雖然服務器以狀態碼200響應回來, 但是控制臺卻報錯了.

這就是Ajax跨域出錯的一種表現, 下面分析原因.

Ajax跨域介紹

  • Ajax跨域問題是由瀏覽器的同源策略造成的, 首先要理解源這個概念.
  • 我們可以通過協議+域名+端口確定一個源. 在上面的示例中, 你可以把一個項目理解為一個源. Ajax請求可以對源內的資源發起訪問, 但是不同源之間進行Ajax就會有問題.
  • 當向不同源的資源發起Ajax請求時, 瀏覽器會加上Origin字段來標識源
Accept: */*Accept-Encoding: gzip, deflate, brAccept-Language: zh-CN,zh;q=0.9Connection: keep-aliveContent-Length: 8Content-Type: application/x-www-form-urlencoded; charset=UTF-8Host: localhost:7070Origin: http://localhost:9090 協議+域名+端口
  • 服務器會根據Origin字段決定是否同意這次請求, 如果Origin指定的源不在許可范圍內, 服務器會返回一個不帶有Access-Control-Allow-Origin字段的響應. 瀏覽器解析時發現缺少了這個字段, 就會報錯. 這種錯誤不能通過狀態碼識別, 因為狀態碼很有可能就是200(見上面的案例).

Ajax跨域解決方案

下面介紹最常用Ajax跨域解決方案.

一. 在服務端添加響應頭Access-Control-Allow-Origin

  • 既然我們已經知道了Ajax跨域失敗是因為響應中缺少了響應頭Access-Control-Allow-Origin, 那么就想辦法加上去.
  • 以Java項目為例, 在后端我們使用CORSFilter過濾器加上該響應頭.
  • (假設是Maven項目), 首先在pom.xml中添加坐標
<dependency> <groupId>com.thetransactioncompany</groupId> <artifactId>cors-filter</artifactId> <version>2.5</version> <scope>runtime</scope></dependency>
  • 然后在web.xml中對過濾器進行配置.
 <filter> <filter-name>CORS</filter-name> <filter-class>com.thetransactioncompany.cors.CORSFilter</filter-class> <init-param>  <param-name>cors.allowOrigin</param-name><!--這個標簽是關鍵, *代表所有源都能訪問-->  <param-value>*</param-value> </init-param> <init-param>  <param-name>cors.supportedMethods</param-name>  <param-value>GET, POST, HEAD, PUT, DELETE</param-value> </init-param> <init-param>  <param-name>cors.supportedHeaders</param-name>  <param-value>Accept, Origin, X-Requested-With, Content-Type, Last-Modified</param-value> </init-param> <init-param>  <param-name>cors.exposedHeaders</param-name>  <param-value>Set-Cookie</param-value> </init-param> <init-param>  <param-name>cors.supportsCredentials</param-name>  <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>CORS</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>

配置后重啟訂單項目, 再次發起Ajax請求可以看到成功返回數據, 響應頭中包含了Access-Control-Allow-Origin, 值為發起Ajax請求的源.



二. 使用JSONP解決

  • 上面直接通過過濾器添加響應頭的方法可以說是對癥下藥, 那么還有沒有什么偏方呢?
  • 還真的有. 在jsp文件中經常通過通過<script>標簽引入一段js代碼, 這段代碼通常來源于網絡, 也就是不同源. 那么我們不妨通過<srcipt>標簽完成Ajax請求, 這樣便順帶解決了跨域問題.
  • 下面還是沿用上面的案例進行演示.
  • 我們對發送ajax的jsp進行修改
<%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head> <title>Title</title> <script type="text/javascript" src="https://code.jquery.com/jquery-1.11.3.js"></script> <script>  function doCallBack(data){   var str = JSON.stringify(data);   alert(str);  } </script></head><body> <script src="http://localhost:7070/order/loadOrderList3?uid=111&callBack=doCallBack"></script></body></html>
  • 上面的代碼中, 我們首先定義了doCallBack()函數, 它接收一個字符串參數, 并且會把接收到的字符串顯示出來.
  • 然后在<body>標簽中編寫<script>標簽, 我們將通過<script>標簽請求訂單系統, 訂單系統將會返回一段js代碼, 這段js代碼會調用doCallBack()方法.
  • 為了能夠拼接出doCallBack(字符串參數...)js代碼, 我們在訂單系統中作如下操作.
@RequestMapping("/loadOrderList3")@ResponseBodypublic String loadOrderList3(String uid, String callBack){ //模擬訂單數據 Order o1 = new Order(); o1.setId("111"); o1.setTotal(333.33); o1.setDate("2019-4-29"); Order o2 = new Order(); o2.setId("222"); o2.setTotal(444.44); o2.setDate("2019-5-29"); Order o3 = new Order(); o3.setId("333"); o3.setTotal(555.55); o3.setDate("2019-6-29"); List<Order> list = new ArrayList<>(); list.add(o1); list.add(o2); list.add(o3); //拼接js代碼 String result = callBack + "(" + JSON.toJSONString(list) + ")"; return result;}

這個想法是不是很妙? 明白這個原理之后, 我們可以使用jQuery方便進行JSONP操作, 在上面的代碼中我們人為指定了一個名為doCallBack的函數, 而jQuery會隨機用時間戳生成一個函數名, 原理和上面是一樣的.

所以完成一開時點擊超鏈接發送Ajax請求只需要如下幾步.

<%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head> <title>Title</title> <script type="text/javascript" src="https://code.jquery.com/jquery-1.11.3.js"></script> <script>  function sendAjax(){   $.getJSON("http://localhost:7070/order/loadOrderList3?callBack=?","uid=111",   function (data) {    var str = JSON.stringify(data);    alert(str);   });  } </script></head><body> <a href="javascript:sendAjax()">sendAjax</a></body></html>

小結

上面兩種解決辦法在思路上有著本質的不同. 方案一抓住CORS跨域訪問問題的本質, 在后端加上響應頭解決跨域問題. 方案二JSONP利用的是<script>標簽能夠跨域獲取js代碼的特性, 繞過跨域問題.

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對的支持。

標簽: Ajax
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
一区二区三区中文字幕精品精品 | 日韩三级在线观看| 首页综合国产亚洲丝袜| 国产欧美三级| 亚洲三级久久久| 国产自产在线视频一区| 国产亚洲精久久久久久| 成人免费毛片嘿嘿连载视频| 91精品福利视频| 日韩精品乱码免费| 一本大道综合伊人精品热热| 日韩国产欧美一区二区三区| 色噜噜久久综合| 琪琪久久久久日韩精品| 色老综合老女人久久久| 青青草视频一区| 欧美日韩和欧美的一区二区| 国产综合久久久久影院| 91精品国产综合久久香蕉的特点| 国产毛片一区二区| 欧美一区二区三区婷婷月色| 国产成人8x视频一区二区| 日韩三级高清在线| 成人黄色在线看| 久久久久久久国产精品影院| 欧美久久久久| 亚洲视频你懂的| 亚洲一区二区动漫| 亚洲国产精品天堂| 久久三级福利| 久久99国产精品成人| 欧美一区二区三区日韩| av激情综合网| 国产精品久久久久永久免费观看 | 欧美性xxxxx极品少妇| 国内成人精品2018免费看| 欧美疯狂性受xxxxx喷水图片| 国产精品18久久久久久久久 | 欧美激情1区| 国产精品污网站| 日韩视频三区| 亚洲成人黄色小说| 欧美性做爰猛烈叫床潮| 国产成人自拍网| 国产免费久久精品| 国产日韩欧美一区二区| 视频在线观看91| 欧美三级电影网| av不卡在线观看| 亚洲三级小视频| 在线一区二区三区| 成人激情小说网站| 亚洲欧美一区二区三区孕妇| 色天天综合久久久久综合片| 国产91在线观看| 亚洲欧洲美洲综合色网| 久久福利电影| 国产激情视频一区二区在线观看 | 一区二区激情小说| 欧美性极品少妇| 成人黄色电影在线| 亚洲视频在线一区| 日本道精品一区二区三区| 成人福利在线看| 一区二区三区影院| 在线播放国产精品二区一二区四区| 白白色 亚洲乱淫| 亚洲精品亚洲人成人网在线播放| 在线看日本不卡| 成人一级视频在线观看| 国产精品国产三级国产三级人妇| 久久资源av| av成人老司机| 亚洲国产成人porn| 日韩女优毛片在线| 亚洲高清123| 美女在线一区二区| 国产夜色精品一区二区av| 久久福利毛片| 成人h版在线观看| 一区二区三国产精华液| 欧美精品一二三四| 亚洲网站啪啪| 精品无人码麻豆乱码1区2区| 国产亚洲精品bt天堂精选| 色又黄又爽网站www久久| 97aⅴ精品视频一二三区| 午夜精品久久久久久久99水蜜桃| 日韩精品一区二区三区swag| 国产一区二区三区久久久久久久久| 国产乱妇无码大片在线观看| 成人免费在线观看入口| 欧美二区乱c少妇| aa国产精品| 成人免费视频播放| 亚洲成人av福利| 精品欧美一区二区三区精品久久| 99精品视频免费观看视频| 国产精品亚洲视频| 一区二区三区在线看| 日韩视频免费观看高清在线视频| 亚洲深夜影院| 波波电影院一区二区三区| 天天综合日日夜夜精品| 国产欧美综合在线观看第十页| 在线视频你懂得一区| 一区二区亚洲精品| 国产盗摄精品一区二区三区在线| 一区二区三区欧美亚洲| 日韩精品资源二区在线| 色综合久久久久| 亚洲午夜高清视频| 国产99久久久国产精品潘金网站| 亚洲图片有声小说| 久久精品人人做人人爽人人| 欧美日韩国产小视频| 国产精品久久久久久模特 | 亚洲永久免费| 女生裸体视频一区二区三区| 国产在线日韩欧美| 亚洲一卡二卡三卡四卡五卡| 国产婷婷色一区二区三区四区 | 国精产品一区一区三区mba视频 | eeuss鲁片一区二区三区在线看| 日韩av网站在线观看| 亚洲欧洲一区二区在线播放| 欧美成人福利视频| 在线观看免费一区| 亚洲一区二区精品在线| 国产在线欧美| 北岛玲一区二区三区四区| 韩国v欧美v日本v亚洲v| 亚洲国产一二三| 国产精品久久看| 亚洲精品在线观看视频| 天天综合色天天综合色h| 欧美一区二区三区久久精品| 一区二区在线观看视频在线观看| 337p粉嫩大胆噜噜噜噜噜91av| 在线观看视频欧美| 国产一区二区久久久| 狠狠久久综合婷婷不卡| 日韩伦理免费电影| 欧美电影免费观看高清完整版在| 悠悠资源网久久精品| 99久久久无码国产精品| 国产乱人伦偷精品视频不卡| 日韩成人免费在线| 亚洲精品一二三| 国产精品免费视频网站| 久久久91精品国产一区二区三区| 久久久99精品免费观看| 久久国产直播| 亚洲精品一级| 欧美日韩91| 91视频免费观看| 不卡电影一区二区三区| 国产另类ts人妖一区二区| 久久成人综合网| 日韩成人精品在线观看| 午夜精品久久久久影视| 亚洲在线一区二区三区| 亚洲欧美激情一区二区| 国产精品久久久久影院老司| 国产欧美在线观看一区| 久久久噜噜噜久久中文字幕色伊伊 | 久久色在线观看| 精品国内二区三区| 日韩女优毛片在线| 日韩一级片网站| 日韩精品中文字幕一区二区三区| 亚洲成精国产精品女| 午夜精品国产更新| 午夜在线成人av| 日韩精品高清不卡| 日日摸夜夜添夜夜添精品视频| 亚洲va欧美va国产va天堂影院| 一区二区欧美国产| 亚洲国产精品尤物yw在线观看| 亚洲成人av免费| 免费一级片91| 激情综合网av| 国产69精品久久久久毛片| 东方aⅴ免费观看久久av| eeuss鲁一区二区三区| 91尤物视频在线观看| 欧美激情第六页| 亚洲国产精品第一区二区| 亚洲日本欧美在线| 午夜在线视频观看日韩17c| 米奇777在线欧美播放| 色老汉av一区二区三区| 91高清视频在线| 精品视频一区二区不卡| 777亚洲妇女| 精品国产伦理网| 欧美激情一区二区三区不卡| 亚洲人成网站影音先锋播放| 亚洲一二三专区| 久久爱www久久做|