實例操作JSONP原理

来源:http://www.cnblogs.com/zqzjs/archive/2016/09/22/5898246.html
-Advertisement-
Play Games

絮語:按這個步驟走,你就會明白JSONP是什麼鬼。 1.工程目錄: 2.nginx的server配置 配置了兩個功能變數名稱不同,埠不同的域。 不會配置? 請看:nginx+php的使用 nginx的使用 3.get的xhr的非同步請求 谷歌下請求沒問題,因為我設置對瀏覽器設置了跨域參數。 但是火狐確是不行 ...


絮語:按這個步驟走,你就會明白JSONP是什麼鬼。

 

1.工程目錄:


 

ng-mywork
    80
        demo.html
    90
        test.js

 

2.nginx的server配置


 

server {
        listen       80;
        server_name  scan_80;

        root E:/ng-mywork/80;

        location / {
            
        }
        
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        
    }

    server {
        listen 90;
        server_name scan_90;

        root E:/ng-mywork/90;

        location / {
            
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

 配置了兩個功能變數名稱不同,埠不同的域。

不會配置?

請看:nginx+php的使用

   nginx的使用

 

 

3.get的xhr的非同步請求


 

//XMLHttpRequest 
// true:非同步請求 
//監聽onreadystatechange事件句柄 
//設置timeout,回調
    var xhr = new XMLHttpRequest();
    xhr.open('get', 'http://scan_90:90/test.js', true);
    xhr.onreadystatechange = function(){
      if(xhr.readyState === 4){
        if(xhr.status === 200){
          alert("請求成功!")
        }
      }
    }
    xhr.ontimeout = function(){
      alert("請求超時")
    }
    xhr.timeout = 1000;
    xhr.send(null);

 

谷歌下請求沒問題,因為我設置對瀏覽器設置了跨域參數。

但是火狐確是不行的,因為是跨域。

 

 

4.get的xhr的同步請求


 

//不能設置超時 因為系統會預設設置為0
    var xhr = new XMLHttpRequest();
    xhr.open('GET', 'http://scan_90:90/test.js', false);
    xhr.send(null);
    if(xhr.readyState === 4){
      if(xhr.status === 200){
        alert("請求成功")
      }

 註意這裡的超時註釋,同步是不能設置的。

 

5.使用jsonp進行跨域解決不能跨域請求的問題


 

//進行jsonp跨域請求
    var script = document.createElement('script');
    script.src = 'http://scan_90:90/test.js?callback=dothings';
    script.type = "text/javascript";
    document.body.insertBefore(script, document.body.children[0]);

 

請求成功了,但是好像跟我們想象的是有點區別的?因為我們常見的返回是這樣的。

dothings([1,2,3]);

//然後我們可以調用:
function dothings(arr){
    //....
}

 

那是因為這不只是前端做的,還有服務端也需要做些修改來配合返回值。

增加php文件:

<?php
    $callback = $_GET['callback'];
    $data = array('1','2','3');
    echo $callback.'('.json_encode($data).')';
?>

 

 改下js:

var script = document.createElement('script');
    script.src = 'http://scan_90:80/test.php?callback=dothings';
    script.type = "text/javascript";
    document.body.insertBefore(script, document.body.children[0]);
    
    //請求完畢後立即執行dothings
    function dothings(arr) {
        console.log(arr)
    }

 

 OK,大功告成!

 

總結:jsonp的跨域使用的就是script可以跨域的特性(還有其他很多標簽都可跨域,如img)。通過服務端跟前端的配合使得返回的js是我們定義的方法,以便可以在前端調用執行。

 


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

-Advertisement-
Play Games
更多相關文章
  • 1. About java利用jdbc直接連接資料庫,經常取得連接,用完釋放,很浪費系統資源 2. Code Java代碼 properties文件(dbcp.properties) 用到的jar ...
  • 題目:輸入n 然後輸入n個整數,用分治法求這n個數中的最大元; 思路:把這列數分成兩半,遞歸下去,到只剩一個數時停止,返回這個數,如果不是一個數則返回分成的兩段數最大值的較大者; 實驗提示:在規模為n的數據元素集合中找出最大元。當n=2時,一次比較就可以找出兩個數據元素的最大元和最小元。當n>2時, ...
  • Atitit.基於dsl的methodinvoker V2 new dyn invoke V3 plan Meth chain Prj cms methd_invok.bat rem a start explorer z: set file=https://dl.pandaidea.com/jarf ...
  • 視頻地址: http://edu.csdn.net/course/detail/602 1. 工廠模式: 1)說明:工廠模式的最大優點在於創建對象上面,就是把創建對象的過程封裝起來,這樣隨時可以產生一個新的對象。 2)詳解:http://www.cnblogs.com/wangtao_20/p/35 ...
  • A集成代碼生成器 [正反雙向(單表、主表、明細表、樹形表,開發利器)+快速構建表單 下載地址 ; freemaker模版技術 ,0個代碼不用寫,生成完整的一個模塊,帶頁面、建表sql腳本,處理類,service等完整模塊B 集成阿裡巴巴資料庫連接池druid; 資料庫連接池 阿裡巴巴的 druid。 ...
  • Atitit. 構造ast 語法樹的總結attilax oao 1. Ast結構樹形1 2. ast view (自是個160k的jar )2 2.1. 多條語句ast結構2 2.2. 變數定義 int b,c; 的ast結構2 2.3. 方法調用meth1(a=1,b=2,c=3); 的ast結構 ...
  • package.json 中包含各種所需模塊以及項目的配置信息(名稱、版本、許可證等)meta 信息。 Name:它屬於必須欄位,在package.json中最重要的就是name和version欄位,如果沒有就無法install。name和version一起組成的標識在假設中是唯一的。改變包應該同時 ...
  • ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...