用jsonp 解決跨域問題

来源:https://www.cnblogs.com/jiaoshuai/archive/2019/05/09/6844993.html
-Advertisement-
Play Games

想自己用 js寫一個原生的ajax請求,訪問本地文件,json/txt。但是demo,寫了一個後,發現 原來是跨域了。 js 寫的原生ajax 請求代碼如下 html代碼 將獲取的txt 文件 展示出來 通過 AJAX 改變內容 js 代碼 function loadX (){ / 老版本的 Int ...


想自己用 js寫一個原生的ajax請求,訪問本地文件,json/txt。但是demo,寫了一個後,發現

原來是跨域了。

                           js 寫的原生ajax 請求代碼如下

html代碼

js 代碼

function loadX (){

    /* 老版本的 Internet Explorer (IE5 和 IE6)使用 ActiveX 對象:
    variable=new ActiveXObject("Microsoft.XMLHTTP");
    為了應對所有的現代瀏覽器,包括 IE5 和 IE6,請檢查瀏覽器是否支持 XMLHttpRequest 對象。
    如果支持,則創建 XMLHttpRequest 對象。如果不支持,則創建 ActiveXObject :*/


    var xmlhttp;
    if(window.XMLHttpRequest){
        xmlhttp = new XMLHttpRequest();     //IE7,FireFox,Chrome,OPera,Safari
    }else{
        xmlhttp = new ActiveXobject('Microsoft.xmlHTTP');  // IE6,IE5
    }   


       /* 屬性    描述
        onreadystatechange  存儲函數(或函數名),每當 readyState 屬性改變時,就會調用該函數。 
        readyState      存有 XMLHttpRequest 的狀態。從 0 到 4 發生變化。
                        0: 請求未初始化
                        1: 伺服器連接已建立
                        2: 請求已接收
                        3: 請求處理中
                        4: 請求已完成,且響應已就緒
          status        200: "OK"
                        404: 未找到頁面

     onreadystatechange 事件中,我們規定當伺服器響應已做好被處理的準備時所執行的任務。
       當 readyState 等於 4 且狀態為 200 時,表示響應已就緒:*/


    //    根據 readyState  值不同,代表響應狀態 的進程
  xmlhttp.onreadystatechange=function(){
      if (xmlhttp.readyState==0){
                  alert(0)
      }
      else if (xmlhttp.readyState==1){
                  alert(1)
      }
      else if (xmlhttp.readyState==2){
                  alert(2)
      }
      else if (xmlhttp.readyState==3){
                  alert(3)
      }
    else if (xmlhttp.readyState==4 && xmlhttp.status==200){
              alert(4)
              document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
      }
  }
        xmlhttp.open('GET','text.txt',true);
        xmlhttp.send(); 

}

txt 文本內的內容

網上查找了方法,可以用jsonp 。於是又去找jsonp 的文檔

1.jsonp簡介
json 是一種數據格式

jsonp 是一種數據調用的方式。

1)什麼是jsonp

為了便於客戶端使用數據,逐漸形成了一種非正式傳輸協議,人們把它稱作JSONP,該協議的一個要點就是允許用戶傳遞一個callback參數給服務端,然後服務端返回數據時會將這個callback參數作為函數名來包裹住JSON數據,這樣客戶端就可以隨意定製自己的函數來自動處理返回數據了。

JSONP的優點是:它不像XMLHttpRequest對象實現的Ajax請求那樣受到同源策略的限制;它的相容性更好,在更加古老的瀏覽器中都可以運行,不需要XMLHttpRequest或ActiveX的支持;並且在請求完畢後可以通過調用callback的方式回傳結果。

2)與ajax的區別

1、ajax和jsonp這兩種技術在調用方式上“看起來”很像,目的也一樣,都是請求一個url,然後把伺服器返回的數據進行處理,因此jQuery和ext等框架都把jsonp作為ajax的一種形式進行了封裝;

2、但ajax和jsonp其實本質上是不同的東西。ajax的核心是通過XmlHttpRequest獲取非本頁內容,而jsonp的核心則是動態添加script標簽來調用伺服器提供的js腳本。

3、所以說,其實ajax與jsonp的區別不在於是否跨域,ajax通過服務端代理一樣可以實現跨域,jsonp本身也不排斥同域的數據的獲取。

4、還有就是,jsonp是一種方式或者說非強制性協議,如同ajax一樣,它也不一定非要用json格式來傳遞數據,如果你願意,字元串都行,只不過這樣不利於用jsonp提供公開服務。

總而言之,jsonp不是ajax的一個特例,儘管jquery等把jsonp封裝進了ajax,也不能改變這一點。

  1. 自己使用jsonp 調用本地文件的demo

index.json 中內容

這樣列印出來的內容就是這樣的


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 淺拷貝:淺拷貝並不拷貝對象本身,只是對指向對象的指針進行拷貝深拷貝:直接拷貝對象到記憶體中一塊區域,然後把新對象的指針指向這塊記憶體 在iOS中並不是所有對象都支持Copy和MutableCopy,遵循NSCopying協議的類可以發送Copy協議,遵循NSMutableCopying協議的類可以發送M ...
  • html 包含兩大部分:head 和 body ; head 部分主要用來放置文檔的頭部,關鍵詞,描述,引入一些外部文件等; body 部分:所有要顯示在瀏覽器中的網頁內容和內容標簽都放在body部分。 ...
  • 使用方法: 調用initMessagebox(“要顯示的文字”)方法即可 用到的css ...
  • 去除jquery-easui tab頁div自帶滾動條 by:授客 QQ:1033553122 測試環境 jquery-easyui-1.5.3 需求場景 打開tab頁面時,自動載入一個iframe頁面,除了iframe頁面本身會出現一個滾動條,tab標簽頁也出現一個滾動條,如下圖所示,需求就是去掉 ...
  • 概念: 2D 動畫要是使用 transform 屬性來實現文字或圖像的的各種變形效果,如位移、縮放、旋轉、傾斜等 transform屬性變形方法: translate():位移 將元素沿著水平方向(X軸)和垂直方向(Y軸)移動 translateX(x):元素僅在水平方向移動(X軸移動) trans ...
  • JS基本概念 JS操作符 JS基本語法 JS數組 JS Date用法 JS 字元串用法 JS編程風格 JS實踐 ...
  • 伺服器端字體 在CSS3中可以使用@font-face屬性來利用伺服器端字體。 @font-face 屬性的使用方法: font-family屬性值中使用webfont來聲明使用的是伺服器端字體 src屬性值中首先指定了字體文件所在的路徑 format聲明字體文件的格式,可以省略文件格式的聲明,單獨 ...
  • 小程式生命周期函數 APP: onlauch:啟動時最先觸發,且全局僅觸發一次! onshow:程式啟動後或者小程式由前臺 後臺觸發 onhide:後臺 前臺觸發 onerroe:報錯 page: onload:文檔載入的時候執行1 onshow: 頁面顯示的時候執行2 onready:頁面除此渲染 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...