JS中實現跨域的方法總結

来源:https://www.cnblogs.com/suihang/archive/2019/03/07/10487498.html
-Advertisement-
Play Games

今天早上在地鐵看了點基礎知識的考察題,看到了一個JS跨域的問題,仔細想了想自己腦子裡竟然只剩下jsonp跨域和用nginx反向代理進行跨域,想著還有別的幾種方法,就是想不起來,這個人呢,一上歲數這個腦子就不好使,為了防止下次又遺忘了,所以特意寫一篇隨筆來記錄一下JS中實現跨域的方式 1.jsonp請 ...


今天早上在地鐵看了點基礎知識的考察題,看到了一個JS跨域的問題,仔細想了想自己腦子裡竟然只剩下jsonp跨域和用nginx反向代理進行跨域,想著還有別的幾種方法,就是想不起來,這個人呢,一上歲數這個腦子就不好使,為了防止下次又遺忘了,所以特意寫一篇隨筆來記錄一下JS中實現跨域的方式

1.jsonp請求

2.document.domain

3.window.name

4.window.postMessage

5.CORS

6.Web Sockets

7.使用伺服器進行反向代理

 

jsonp請求

  jsonp的原理時利用script標簽的跨域特性,可以不受限制的從其他域中載入資源,類似的標簽還有<img>,具體的使用方法在我前面的博文中已經寫過,

  註意:jsonp只支持GET請求而不支持其他類型的請求

doucment.domain

  這種方式主要用在主功能變數名稱相同,子功能變數名稱不同的情況下

window.name

  window的name屬性有個特征:在一個視窗(window)的生命周期內,視窗所載入的所有頁面都是共用一個window.name,每個頁面對window.name都有讀寫許可權,window.name是持久存在一個視窗載入過的所有頁面中的,並不會因新頁面的載入而進行重置

window.postMessage

  window.postMessage是html5中實現跨域訪問的一種新方式,可以使用它來向其他的window對象發送消息,無論這個window對象是屬於同源還是不同源

CORS

  CORS背後的基本思想,就是使用自定義的HTTP頭部讓瀏覽器和伺服器進行溝通,從而決定請求或響應是應該成功還是應該失敗,

  這個需要伺服器設置header :Access-Control-Allow-Origin即可

webSocket

  webSocket的原理:在JSchuangjianlewebSocket之後,會有一個HTTP請求發送到瀏覽器以發起鏈接,取得伺服器響應後,建立的連接會使用HTTP升級從HTTP協議交換為websocket協議

使用伺服器進行反向代理

  我個人常用的nginx進行反向代理,之前也試過用nodeJS自己搭建一個伺服器進行反向代理,具體的步驟暫時不詳述,各位可以搜一下,一搜一大堆

 

好了,暫時的話就這些,但是我在工作中常用的還是最後一種用nginx伺服器進行反向代理

 


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

-Advertisement-
Play Games
更多相關文章
  • 協同辦公衍生出的需求 1.業務需求 1.1.流程 先說業務流程: 現在辦公基本上都是諸如 之類的線上office來協同辦公,然後所有的線上文檔會有一份本地文件用來存儲和數據分析 1.2.需求 需求是這樣的: 希望企業系統和文職人員以及分析部能夠共同管理這些Excel表格,但不想耗費資源去開發OA之類 ...
  • 1,先到Oracle站點下載Instant Client : http://www.oracle.com/technology/global/cn/software/tech/oci/instantclient/index.html 依據你的操作系統選擇不同的Instant Client版本號 下載 ...
  • [20190306]奇怪的查詢結果.txt--//鏈接http://www.itpub.net/thread-2108588-1-1.html提到一個非常古怪的問題,我自己重覆測試看看:1.環境:SCOTT@book> @ ver1PORT_STRING VERSION BANNER x86_64/ ...
  • 概述 UIStepper用於增加或減少值的控制項。 屬性和方法 初始化方法 UIStepper *stepper = [[UIStepper alloc] initWithFrame:CGRectMake(100, 100, 100, 30)]; 設置是否為連續狀態 [stepper setConti ...
  • 概述 UIButton 是執行自定義代碼以響應用戶交互的控制項。 UIButton 其實包含 UIImageView 和 UILabel 兩個控制項,UIButton 繼承於 UIControl,所以有 addtarget 監聽事件 屬性和方法 初始化Button不用alloc init方法,使用便利構 ...
  • //創建文件 NSString *documentsDirectory = [NSHomeDirectory() stringByAppendingPathComponent:@"Documents"]; NSFileManager *fileManager = [NSFileManager def... ...
  • 前不久才接觸到 純粹用手機 進行編程的開發者, 當時頗有孤陋寡聞之感, 因為之前聽說過手機編程還是一些線上編程學習網站開發的學習環境, 沒有想過真的有用它做實際開發的. 此文用AIDE免費版在自己的手機上做一個最簡單的應用, 參考的是AIDE官方的入門文檔: "AIDE Android IDE" . ...
  • 在Activity中可以直接使用 就可以重寫 onCreateOptionsMenu 和 onOptionsItemSelected 方法; 但是在Fragment中則需要 Fragment中需要將 getActivity()轉為AppCompatActivity才能獲取setSupportActi ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...