欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解IOS WebRTC的實(shí)現(xiàn)原理

 更新時(shí)間:2021年06月07日 11:04:31   作者:為童沉淪  
WebRTC,源自網(wǎng)頁實(shí)時(shí)通信(Web Real-Time Communication)縮寫,它是支持網(wǎng)頁瀏覽器進(jìn)行實(shí)時(shí)語音對(duì)話或視頻對(duì)話的技術(shù)。它為我們提供了視頻會(huì)議的核心技術(shù),包括音視頻的采集、編解碼、網(wǎng)絡(luò)傳輸、顯示等功能,并且還支持跨平臺(tái):windows,linux,mac,android,ios。

概述

它在2011年5月開放了工程的源代碼,在行業(yè)內(nèi)得到了廣泛的支持和應(yīng)用,成為下一代視頻通話的標(biāo)準(zhǔn)。

WebRTC的音視頻通信是基于P2P,那么什么是P2P呢?

它是點(diǎn)對(duì)點(diǎn)連接的英文縮寫。

P2P連接模式

一般我們傳統(tǒng)的連接方式,都是以服務(wù)器為中介的模式:

類似http協(xié)議:客戶端?服務(wù)端(當(dāng)然這里服務(wù)端返回的箭頭僅僅代表返回請(qǐng)求數(shù)據(jù))。

我們?cè)谶M(jìn)行即時(shí)通訊時(shí),進(jìn)行文字、圖片、錄音等傳輸?shù)臅r(shí)候:客戶端A?服務(wù)器?客戶端B。

而點(diǎn)對(duì)點(diǎn)的連接恰恰數(shù)據(jù)通道一旦形成,中間是不經(jīng)過服務(wù)端的,數(shù)據(jù)直接從一個(gè)客戶端流向另一個(gè)客戶端:

客戶端A?客戶端B ... 客戶端A?客戶端C ...(可以無數(shù)個(gè)客戶端之間互聯(lián))

這里可以想想音視頻通話的應(yīng)用場(chǎng)景,我們服務(wù)端確實(shí)是沒必要去獲取兩者通信的數(shù)據(jù),而且這樣做有一個(gè)最大的一個(gè)優(yōu)點(diǎn)就是,大大的減輕了服務(wù)端的壓力。

而WebRTC就是這樣一個(gè)基于P2P的音視頻通信技術(shù)。

WebRTC的服務(wù)器與信令

講到這里,可能大家覺得WebRTC就不需要服務(wù)端了么?這是顯然是錯(cuò)誤的認(rèn)識(shí),嚴(yán)格來說它僅僅是不需要服務(wù)端來進(jìn)行數(shù)據(jù)中轉(zhuǎn)而已。

WebRTC提供了瀏覽器到瀏覽器(點(diǎn)對(duì)點(diǎn))之間的通信,但并不意味著WebRTC不需要服務(wù)器。暫且不說基于服務(wù)器的一些擴(kuò)展業(yè)務(wù),WebRTC至少有兩件事必須要用到服務(wù)器:

  • 瀏覽器之間交換建立通信的元數(shù)據(jù)(信令)必須通過服務(wù)器。
  • 為了穿越NAT和防火墻。

第1條很好理解,我們?cè)贏和B需要建立P2P連接的時(shí)候,至少要服務(wù)器來協(xié)調(diào),來控制連接開始建立。而連接斷開的時(shí)候,也需要服務(wù)器來告知另一端P2P連接已斷開。這些我們用來控制連接的狀態(tài)的數(shù)據(jù)稱之為信令,而這個(gè)與服務(wù)端連接的通道,對(duì)于WebRTC而言就是信令通道。

圖中signalling就是往服務(wù)端發(fā)送信令,然后底層調(diào)用WebRTC,WebRTC通過服務(wù)端得到的信令,得知通信對(duì)方的基本信息,從而實(shí)現(xiàn)虛線部分Media通信連接。

當(dāng)然信令能做的事還有很多,這里大概列了一下:

  • 用來控制通信開啟或者關(guān)閉的連接控制消息
  • 發(fā)生錯(cuò)誤時(shí)用來彼此告知的消息
  • 媒體流元數(shù)據(jù),比如像解碼器、解碼器的配置、帶寬、媒體類型等等
  • 用來建立安全連接的關(guān)鍵數(shù)據(jù)
  • 外界所看到的的網(wǎng)絡(luò)上的數(shù)據(jù),比如IP地址、端口等

在建立連接之前,客戶端之間顯然沒有辦法傳遞數(shù)據(jù)。所以我們需要通過服務(wù)器的中轉(zhuǎn),在客戶端之間傳遞這些數(shù)據(jù),然后建立客戶端之間的點(diǎn)對(duì)點(diǎn)連接。但是WebRTC API中并沒有實(shí)現(xiàn)這些,這些就需要我們來實(shí)現(xiàn)了。

而第2條中的NAT這個(gè)概念,參考文章iOS即時(shí)通訊,從入門到“放棄”?,中也提到過,不過是為了應(yīng)對(duì)NAT超時(shí),所造成的TCP連接中斷。在這里我們就不展開去講了,感興趣的可以看看:NAT百科

這里我簡(jiǎn)要說明一下,NAT技術(shù)的出現(xiàn),其實(shí)就是為了解決IPV4下的IP地址匱乏。舉例來說,就是通常我們處在一個(gè)路由器之下,而路由器分配給我們的地址通常為192.168.0.1 、192.168.0.2如果有n個(gè)設(shè)備,可能分配到192.168.0.n,而這個(gè)IP地址顯然只是一個(gè)內(nèi)網(wǎng)的IP地址,這樣一個(gè)路由器的公網(wǎng)地址對(duì)應(yīng)了n個(gè)內(nèi)網(wǎng)的地址,通過這種使用少量的公有IP 地址代表較多的私有IP 地址的方式,將有助于減緩可用的IP地址空間的枯竭。

但是這也帶來了一系列的問題,例如這里點(diǎn)對(duì)點(diǎn)連接下,會(huì)導(dǎo)致這樣一個(gè)問題:

如果客戶端A想給客戶端B發(fā)送數(shù)據(jù),則數(shù)據(jù)來到客戶端B所在的路由器下,會(huì)被NAT阻攔,這樣B就無法收到A的數(shù)據(jù)了。

但是A的NAT此時(shí)已經(jīng)知道了B這個(gè)地址,所以當(dāng)B給A發(fā)送數(shù)據(jù)的時(shí)候,NAT不會(huì)阻攔,這樣A就可以收到B的數(shù)據(jù)了。這就是我們進(jìn)行NAT穿越的核心思路。

于是我們就有了以下思路:

我們借助一個(gè)公網(wǎng)IP服務(wù)器,a,b都往公網(wǎng)IP/PORT發(fā)包,公網(wǎng)服務(wù)器就可以獲知a,b的IP/PORT,又由于a,b主動(dòng)給公網(wǎng)IP服務(wù)器發(fā)包,所以公網(wǎng)服務(wù)器可以穿透NAT A,NAT B送包給a,b。

所以只要公網(wǎng)IP將b的IP/PORT發(fā)給a,a的IP/PORT發(fā)給b。這樣下次a和b互相消息,就不會(huì)被NAT阻攔了。

WebRTC的NAT/防火墻穿越技術(shù)

基于上述的一個(gè)思路來實(shí)現(xiàn)的:

建立點(diǎn)對(duì)點(diǎn)信道的一個(gè)常見問題,就是NAT穿越技術(shù)。在處于使用了NAT設(shè)備的私有TCP/IP網(wǎng)絡(luò)中的主機(jī)之間需要建立連接時(shí)需要使用NAT穿越技術(shù)。以往在VoIP領(lǐng)域經(jīng)常會(huì)遇到這個(gè)問題。目前已經(jīng)有很多NAT穿越技術(shù),但沒有一項(xiàng)是完美的,因?yàn)镹AT的行為是非標(biāo)準(zhǔn)化的。這些技術(shù)中大多使用了一個(gè)公共服務(wù)器,這個(gè)服務(wù)使用了一個(gè)從全球任何地方都能訪問得到的IP地址。在RTCPeeConnection中,使用ICE框架來保證RTCPeerConnection能實(shí)現(xiàn)NAT穿越

這里提到了ICE協(xié)議框架,它大約是由以下幾個(gè)技術(shù)和協(xié)議組成的:STUN、NAT、TURN、SDP,這些協(xié)議技術(shù),幫助ICE共同實(shí)現(xiàn)了NAT/防火墻穿越。

以上就是詳解IOS WebRTC的實(shí)現(xiàn)原理的詳細(xì)內(nèi)容,更多關(guān)于IOS WebRTC的實(shí)現(xiàn)原理的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • iOS實(shí)現(xiàn)通過按鈕添加和刪除控件的方法

    iOS實(shí)現(xiàn)通過按鈕添加和刪除控件的方法

    這篇文章主要為大家詳細(xì)介紹了iOS通過按鈕添加和刪除控件的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • iOS中l(wèi)ebel特殊字符的自動(dòng)換行問題解決

    iOS中l(wèi)ebel特殊字符的自動(dòng)換行問題解決

    這篇文章主要給大家介紹了關(guān)于iOS中l(wèi)ebel特殊字符的實(shí)現(xiàn)不自動(dòng)換行的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)iOS具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-10-10
  • iOS使用GCDSocketManager實(shí)現(xiàn)長(zhǎng)連接的方法

    iOS使用GCDSocketManager實(shí)現(xiàn)長(zhǎng)連接的方法

    下面想就為大家分享一篇iOS使用GCDSocketManager實(shí)現(xiàn)長(zhǎng)連接的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • iOS指紋登錄(TouchID)集成方案詳解

    iOS指紋登錄(TouchID)集成方案詳解

    這篇文章主要為大家詳細(xì)介紹了iOS指紋登錄TouchID的集成方案,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • iOS中程序異常Crash友好化處理詳解

    iOS中程序異常Crash友好化處理詳解

    在iOS開發(fā)調(diào)試過程中以及上線之后,程序經(jīng)常會(huì)出現(xiàn)崩潰的問題,下面這篇文章主要給大家介紹了關(guān)于iOS中程序異常Crash友好化處理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-07-07
  • iOS開發(fā)筆記之鍵盤、靜態(tài)庫、動(dòng)畫和Crash定位

    iOS開發(fā)筆記之鍵盤、靜態(tài)庫、動(dòng)畫和Crash定位

    最近在學(xué)習(xí)iOS開發(fā),進(jìn)行了一些實(shí)戰(zhàn),所以下面這篇文章主要給大家介紹了關(guān)于iOS開發(fā)筆記之鍵盤、靜態(tài)庫、動(dòng)畫和Crash定位的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-04-04
  • iOS開發(fā)中多線程的安全隱患總結(jié)

    iOS開發(fā)中多線程的安全隱患總結(jié)

    在本篇文章中小編給大家整理了關(guān)于iOS開發(fā)中多線程的安全隱患的知識(shí)點(diǎn),需要的朋友們學(xué)習(xí)參考下。
    2019-07-07
  • iOS的音頻文件的格式轉(zhuǎn)換示例

    iOS的音頻文件的格式轉(zhuǎn)換示例

    這篇文章主要介紹了iOS的音頻文件的格式轉(zhuǎn)換示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • iOS App開發(fā)中UISearchBar搜索欄組件的基本用法整理

    iOS App開發(fā)中UISearchBar搜索欄組件的基本用法整理

    iOS開發(fā)組件中自帶的UISearchBar提供了很多基礎(chǔ)和好用的搜索欄UI功能,下面就來總結(jié)一下iOS App開發(fā)中UISearchBar搜索欄組件的基本用法整理,需要的朋友可以參考下
    2016-05-05
  • iOS中Runtime的幾種基本用法記錄

    iOS中Runtime的幾種基本用法記錄

    RunTime顧名思義運(yùn)行時(shí),就是系統(tǒng)在運(yùn)行的時(shí)候的一些機(jī)制,最主要的是消息機(jī)制。下面這篇文章主要給大家介紹了關(guān)于iOS中Runtime的幾種基本用法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07

最新評(píng)論