項目復盤:websocket不受跨域限制的原理

主要還是因為:

1、WebSocket 是獨立于 HTTP 的應用層協議,通過 HTTP 建立連接后,完全脫離 HTTP 語義約束。這意味著

  • 不受 HTTP 同源策略限制

  • 不需要預檢請求

  • 不依賴 CORS 頭機制

2、建立連接時的握手請求仍使用 HTTP 格式,但具有特殊標記:

類似于下述代碼,當瀏覽器發起 WebSocket 連接時,會自動將當前網頁的源(協議+域名+端口)填入?Origin?請求頭。內部實現了跨域

GET /chat HTTP/1.1
Host: server.example.com
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Key: dGhlIHNhbXBsZSBub25jZQ==
Origin: https://client.example.com  // 關鍵跨域標識
Sec-WebSocket-Version: 13

? ?注:雖然目前服務端不做白名單校驗也能成功,但為了安全還是要做一下di~

? ?服務端可以用下列代碼進行驗證以防惡意操作

wss.on('connection', (ws, req) => {
// 進行白名單校驗const allowedOrigins = ['https://myapp.com', 'https://admin.myapp.com'];if (!allowedOrigins.includes(req.headers.origin)) {ws.close(1008, 'Invalid origin'); // 關閉非法來源連接return;}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/74853.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/74853.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/74853.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

COMPASS:通過殘差強化學習和技能合成實現跨具身移動策略

25年2月來自 Nvidia、UC Berkeley 和 UT Austin 的論文“COMPASS: Cross-embOdiment Mobility Policy via ResiduAl RL and Skill Synthesis”。 隨著機器人越來越多地部署在不同的應用領域,可泛化的跨具身移動策略變得越來越重要。雖然經典的移動棧已被證明在特定…

無人機,雷達定點飛行時,位置發散,位置很飄,原因分析

參考: 無人車傳感器 IMU與GPS數據融合進行定位機制_gps imu 組合定位原始數-CSDN博客 我的無人機使用雷達定位,位置模式很飄 雷達的更新頻率也是10HZ, 而px飛控的頻率是100HZ,沒有對兩者之間的頻率差異做出處理 所以才導致無人…

學習threejs,使用Sprite精靈、SpriteMaterial精靈材質

👨??? 主頁: gis分享者 👨??? 感謝各位大佬 點贊👍 收藏? 留言📝 加關注?! 👨??? 收錄于專欄:threejs gis工程師 文章目錄 一、🍀前言1.1 ??THREE.Sprite1.1.1 ??代碼…

外星人入侵(python設計小游戲)

這個游戲簡而言之就是操作一個飛機對前方的飛船進行射擊,和一款很久之前的游戲很像,這里是超級低配版那個游戲,先來看看效果圖: 由于設計的是全屏的,所以電腦不能截圖。。。。 下面的就是你操控的飛船,上面…

什么是CMS?常用CMS有哪些?

一、內容管理系統(Content Management System)? ?什么是CMS?:位于 Web 前端(服務器)和后端辦公系統之間的軟件系統,用于內容創建、編輯、審批和發布。支持文本、圖片、視頻、數據庫等各類數字內容的管理…

Go 語言規范學習(3)

文章目錄 Properties of types and valuesRepresentation of valuesUnderlying types【底層類型】Core types【核心類型】Type identityAssignabilityRepresentabilityMethod sets BlocksDeclarations and scopeLabel scopesBlank identifierPredeclared identifiersExported i…

在 Ubuntu 上安裝 Docker 的完整指南

1. 卸載舊版本(如有) 在安裝新版本前,建議先卸載舊版本: sudo apt remove docker docker-engine docker.io containerd runc 2. 安裝依賴包 更新軟件包索引并安裝必要的依賴: sudo apt update sudo apt install -y ca-certificates curl gnupg lsb-release 3. 添加 Do…

turtle的九個使用

一 import turtle as t color [red,green,blue,orange,pink] for i in range(len(color)):t.penup()t.goto(-20070*i,0)t.pendown()t.pencolor(color[i])t.circle(50, steps 5) t.done()二 #在____________上補充代碼 #不要修改其他代碼import random as r import turtle a…

23種設計模式-備忘錄(Memento)設計模式

備忘錄設計模式 🚩什么是備忘錄設計模式?🚩備忘錄設計模式的特點🚩備忘錄設計模式的結構🚩備忘錄設計模式的優缺點🚩備忘錄設計模式的Java實現🚩代碼總結🚩總結 🚩什么是…

利用虛擬化技術實現高級Hook

虛擬化技術為系統監控和Hook提供了更強大、更隱蔽的實現方式。以下是幾種基于虛擬化的Hook技術實現方法: 1. 基于VT-x/AMD-V的硬件虛擬化Hook 基本原理 利用CPU的硬件虛擬化擴展(Intel VT-x/AMD-V)在Ring -1層級監控系統行為,實現無法被常規方法檢測的…

某魚、某寶 sign 簽名算法分析記錄

【作者主頁】:小魚神1024 【知識星球】:小魚神的逆向編程圈 【擅長領域】:JS逆向、小程序逆向、AST還原、驗證碼突防、Python開發、瀏覽器插件開發、React前端開發、NestJS后端開發等等 本文章中所有內容僅供學習交流使用,不用于其…

Compose筆記(十三)--事件總線

這一節了解一下Compose中的事件總線,在Jetpack Compose里,官方沒有直接提供事件總線,但可以借助第三方庫或者自定義實現來達成事件總線的功能,進而在不同的 Compose 控件間同步數據。 自定義事件總線 import androidx.compose.r…

Python的inspect模塊

在Python編程中,**inspect**模塊是一個強大的工具包,它提供了一系列函數來獲取對象的信息,主要用于獲取對象的源代碼、參數信息、類繼承關系、方法屬性等。這對于調試、自動化文檔生成、代碼分析等場景都非常有用。本文將詳細介紹inspect模塊…

2025跳槽學習計劃

(1)編程基礎: 目錄學習資料Chttps://www.bilibili.com/video/BV1z64y1U7hs?spm_id_from333.1387.favlist.content.clickLinuxPytorchhttps://www.bilibili.com/video/BV1if4y147hS?spm_id_from333.1387.favlist.content.clickopencv數據結…

WebRTC簡介及應用

WebRTC(Web Real-Time Communication)是一種支持瀏覽器和移動設備進行實時音視頻通信的技術,無需安裝插件或額外的軟件。它是一個開放標準,最初由Google推動,并被W3C(萬維網聯盟)和IETF&#xf…

【C語言】分支與循環(上)

前言:C語言是由順序結構、選擇結構、循環結構組成的結構化的程序設計語言。 那C語言是如何設計和實現這些結構的呢?話不多說,馬上開始。 三種結構如圖所示: 我們可以使用 if else語句、 switch語句 來實現選擇(分支&am…

一次與chatgpt關于VO的深入討論。

我: {"usageRate":50,"projectInfo":[{"productName":"長江一號","deviceInfo":[{"deviceName":"AA","num":10},{"deviceName":"BB","num":3}]},…

Springboot學習筆記3.20

目錄 1.實戰篇第一課 我們將會在本次實戰中學習到哪些知識點? 開發模式和環境搭建: 注冊接口 1.Lombok 2.開發流程 1.controller層,這個層會指明訪問路徑和要執行的邏輯: 2.我們把返回結果根據接口文檔包裝成一個類result&a…

docker save如何遷移鏡像更節省空間?

文章目錄 方法一:使用docker save命令方法二:直接保存多個鏡像到一個tar文件哪個方法更節省磁盤空間?空間效率對比實際測試示例其他優勢結論 如何用腳本遷移加載鏡像 遷移鏡像時候,往往會碰到基礎鏡像相同的很多鏡像需要遷移&…

全新升級 | Built For You Spring ‘25 發布,Fin 智能客服實現新突破!

圖像識別、語音交互、任務自動化,立即體驗智能客服蛻變! 上周,Intercom 舉辦了 Built For You Spring 25 發布會,正式揭曉了 AI Agent Fin 的一系列令人振奮的更新。Fin 正在以前所未有的速度革新客戶支持模式——它已經成功解決了…