国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

使用WebRTC搭建前端視頻聊天室——點對點通信篇

xuweijian / 2574人閱讀

摘要:如果對和不太了解的同學(xué),可以先閱讀如下文章的使用搭建前端視頻聊天室信令篇使用搭建前端視頻聊天室入門篇老劉和老姚當(dāng)然服務(wù)器完全不參與其中,顯然是不可能的,用戶需要通過服務(wù)器上存儲的信息,才能確定需要和誰建立連接。

WebRTC給我們帶來了瀏覽器中的視頻、音頻聊天體驗。但個人認為,它最實用的特性莫過于DataChannel——在瀏覽器之間建立一個點對點的數(shù)據(jù)通道。在DataChannel之前,瀏覽器到瀏覽器的數(shù)據(jù)傳遞通常是這樣一個流程:瀏覽器1發(fā)送數(shù)據(jù)給服務(wù)器,服務(wù)器處理,服務(wù)器再轉(zhuǎn)發(fā)給瀏覽器2。這三個過程都會帶來相應(yīng)的消耗,占用服務(wù)器帶寬不說,還減緩了消息從發(fā)送到接收的時間。其實最理想的方式就是瀏覽器1直接與瀏覽2進行通信,服務(wù)器不需要參與其中。WebRTC DataChannel就提供了這樣一種方式。

如果對WebRTC和DataChannel不太了解的同學(xué),可以先閱讀如下文章:
- WebRTC的RTCDataChannel
- 使用WebRTC搭建前端視頻聊天室——信令篇
- 使用WebRTC搭建前端視頻聊天室——入門篇

老劉和老姚

當(dāng)然服務(wù)器完全不參與其中,顯然是不可能的,用戶需要通過服務(wù)器上存儲的信息,才能確定需要和誰建立連接。這里通過一個故事來講述建立連接的過程:

不如釣魚去

一些背景:
- 老劉和老姚都住在同一個小區(qū)但不同的片區(qū),小區(qū)很破舊,沒有電話
- 片區(qū)相互隔離且片區(qū)門口有個保安,保安只認識自己片區(qū)的人,遇到不認識的人就需要查詢憑證才能通過,而憑證需要找物業(yè)才能確定
- 門衛(wèi)老大爺認識小區(qū)里的所有人但是不知道都住哪,有什么消息都可以在出入小區(qū)的時候代為傳達

現(xiàn)在,老劉聽說老姚釣魚技術(shù)高超,想和老姚討論釣魚技巧。只要老劉和老姚相互之間知道對方的門牌號以及憑證,就可以串門了:

門衛(wèi)老大爺認識老劉和老姚

老劉找物業(yè)確定了自己片區(qū)的出入憑證,將憑證、自己的門牌號以及意圖告訴門衛(wèi)老大爺,讓其轉(zhuǎn)交給老姚

老姚買菜歸來遇到門衛(wèi)老大爺,門衛(wèi)老大爺將老劉的消息傳達給老姚。于是老姚知道怎么去老劉家了

老姚很開心,他也找物業(yè)獲取了自己小區(qū)的憑證,并將憑證、自己的門牌號等信息交給門衛(wèi)老大爺,希望他傳達給老劉

老劉吃早餐回來遇到門衛(wèi)老大爺,老大爺把老姚的小區(qū)憑證、門牌號等信息告訴老劉,這樣老劉就知道了怎么去老姚家了

老劉和老姚相互之間知道了對方的門牌號和小區(qū)出入憑證,他們相互之間有什么需要交流的直接串門就行了,消息不再需要門衛(wèi)老大爺來代為傳達了

換個角度

我們把角色做一個映射:
- 老劉:瀏覽器1
- 老姚:瀏覽器2
- 片區(qū):不同網(wǎng)段
- 保安:防火墻
- 片區(qū)憑證:ICE candidate
- 物業(yè):ICE server
- 門牌號:session description
- 門衛(wèi)老大爺:server

于是乎故事就變成了這樣:

瀏覽器1和瀏覽器2在server上注冊,并保有連接

瀏覽器1從ice server獲取ice candidate并發(fā)送給server,并生成包含session description的offer,發(fā)送給server

server發(fā)送瀏覽器1的offer和ice candidate給瀏覽器2

瀏覽器2發(fā)送包含session description的answer和ice candidate給server

server發(fā)送瀏覽器2的answer和ice candidate給瀏覽器1

這樣,就建立了一個點對點的信道,流程如下所示:

禮物 故事

老劉和老姚已經(jīng)可以相互串門了,經(jīng)過一段時間的交流感情越來越深。老姚的親友送了20斤葡萄給老姚,老姚決定送10斤給老劉。老姚畢竟年事已高,不可能一次帶10斤。于是乎,老姚將葡萄分成了10份,每次去老劉家串門就送一份過去。

這里可以做如下類比:
1. 10斤葡萄:一個文件(盡管文件分片沒有意義,葡萄分開還可以多帶帶吃,但是實在找不到啥好的比喻了)
2. 分成10份:將文件分片,轉(zhuǎn)成多個chunk
3. 老姚一次只能帶一斤:datachannel每次傳輸?shù)臄?shù)據(jù)量不宜太大(找到最合適的大小)

這其實就是通過datachannel傳輸文件的方式,首先將文件分片,然后逐個發(fā)送,最后再統(tǒng)一的進行組合成一個新的文件

分片

通過HTML5的File API可以將type為file的input選中的文件讀取出來,并轉(zhuǎn)換成data url字符串。這也就為我們提供了很方便的分片方式:

var reader = new window.FileReader(file);
reader.readAsDataURL(file);
reader.onload = function(event, text) {
    chunkify(event.target.result);//將數(shù)據(jù)分片
};
組合

通過datachannel發(fā)送的分片數(shù)據(jù),我們需要將其進行組合,由于是data url字符串,在接收到所有包之后進行拼接就可以了。拼接完成后就得到了一個文件完整的data url字符串,那么我們?nèi)绾螌⑦@個字符串轉(zhuǎn)換成文件呢?

方案一:直接跳轉(zhuǎn)下載

既然是個dataurl,我們直接將其賦值給window.location.href自然可以下載,但是這樣下載是沒法設(shè)定下載后的文件名的,這想一想都蛋疼

方案二:通過a標(biāo)簽下載

這個原理和跳轉(zhuǎn)下載類似,都是使用dataurl本身的特性,通過創(chuàng)建一個a標(biāo)簽,將dataurl字符串賦值給href屬性,然后使用download確定下載后的文件名,就可以完成下載了。但是很快又有新問題了,稍微大一點的文件下載的時候頁面崩潰了。這是因為dataurl有大小限制

方案三:blob

其實可以通過給a標(biāo)簽創(chuàng)建blob url的方式來進行下載,這個沒有大小限制。但是我們手上是dataurl,所以需要先進行轉(zhuǎn)換:

function dataURItoBlob(dataURI, dataTYPE) {
    var binary = atob(dataURI.split(",")[1]),
        array = [];
    for (var i = 0; i < binary.length; i++) array.push(binary.charCodeAt(i));
    return new Blob([new Uint8Array(array)], {
        type: dataTYPE
    });
}

獲得blob后,我們就可以通過URL API來下載了:

var a = document.createElement("a");
document.body.appendChild(a);
a.style = "display: none";
var blob = dataURItoBlob(data, "octet/stream");
var url = window.URL.createObjectURL(blob);
a.href = url;
a.download = filename;
a.click();
!moz && window.URL.revokeObjectURL(url);
a.parentNode.removeChild(a);

這里有幾個點:
1. datachannel其實是可以直接傳送blob的,但是只有ff支持,所以傳data url
2. chrome下載是直接觸發(fā)的,不會進行詢問,firefox會先詢問后下載,在詢問過程中如果執(zhí)行了revokeObjectURL,下載就會取消,囧

升級

如我們所知,WebRTC最有特點的地方其實是可以傳輸getUserMedia獲得的視頻、音頻流,來實現(xiàn)視頻聊天。但事實上我們的使用習(xí)慣來看,一般人不會一開始就打開視頻聊天,而且視頻聊天時很消耗內(nèi)存的(32位機上一個連接至少20M左右好像,也有可能有出入)。所以常見的需求是,先建立一個包含datachannel的連接用于傳輸數(shù)據(jù),然后在需要時升級成可以傳輸視頻、音頻。

看看我們之前傳輸?shù)膕ession description,它其實來自Session Description Protocol。可以看到wiki上的介紹:

  

The Session Description Protocol (SDP) is a format for describing streaming media initialization parameters.

這意味著什么呢?我們之前建立datachannel是沒有加視頻、音頻流的,而這個流的描述是寫在SDP里面的。現(xiàn)在我們需要傳輸視頻、音頻,就需要添加這些描述。所以就得重新獲得SDP,然后構(gòu)建offer和answer再傳輸一次。傳輸?shù)牧鞒毯椭耙粯樱瑳]什么區(qū)別。但這一次,我們不需要傳輸任何的ice candidate,這里我曾經(jīng)遇到了坑,經(jīng)過國外大大的點撥才明白過來。

  

from mattm: You do not need to send ICE candidates on an already established peer connection. The ICE candidates are to make sure the two peers can establish a connection through their potential NAT and firewalls. If you can already send data on the peer connection, ICE candidates will not do anything.

Peertc

我將datachannel和websocket組合,實現(xiàn)了一個構(gòu)建點對點連接的庫Peertc,它提供非常簡潔的方式來建立連接和發(fā)送數(shù)據(jù)、文件和視頻/音頻流,詳情見github。走過路過的記得star一下哦,有什么bug也非常希望能夠提出來。

最后

WebRTC的點對點方式能夠運用在很多場景:
- 如web qq這種Web IM工具,這就不說了
- 如象棋這種雙人對戰(zhàn)游戲,每一步的數(shù)據(jù)服務(wù)器時不關(guān)心的,所以完全可以點對點發(fā)送
- 一對一在線面試、在線教育,這其實是即時通信的一個業(yè)務(wù)方向
- 視頻裸(),當(dāng)我沒說

就醬,另外打個廣告及拉點搜索引擎權(quán)重:我的博客

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/64169.html

相關(guān)文章

  • 使用WebRTC搭建前端視頻天室——入門

    摘要:在處于使用了設(shè)備的私有網(wǎng)絡(luò)中的主機之間需要建立連接時需要使用穿越技術(shù)。目前已經(jīng)有很多穿越技術(shù),但沒有一項是完美的,因為的行為是非標(biāo)準(zhǔn)化的。 什么是WebRTC? 眾所周知,瀏覽器本身不支持相互之間直接建立信道進行通信,都是通過服務(wù)器進行中轉(zhuǎn)。比如現(xiàn)在有兩個客戶端,甲和乙,他們倆想要通信,首先需要甲和服務(wù)器、乙和服務(wù)器之間建立信道。甲給乙發(fā)送消息時,甲先將消息發(fā)送到服務(wù)器上,服務(wù)器對甲...

    Carl 評論0 收藏0
  • 使用WebRTC搭建前端視頻天室——數(shù)據(jù)通道

    摘要:最后,消息成功抵達并顯示在頁面上。在中,所有的數(shù)據(jù)都使用數(shù)據(jù)報傳輸層安全性。如果應(yīng)用知識簡單的一對一文件傳輸,使用不可靠的數(shù)據(jù)通道將需要設(shè)計一定的響應(yīng)重傳協(xié)議。目前建議的最大塊大小為。 本文翻譯自WebRTC data channels 在兩個瀏覽器中,為聊天、游戲、或是文件傳輸?shù)刃枨蟀l(fā)送信息是十分復(fù)雜的。通常情況下,我們需要建立一臺服務(wù)器來轉(zhuǎn)發(fā)數(shù)據(jù),當(dāng)然規(guī)模比較大的情況下,會擴展成...

    qpal 評論0 收藏0
  • 使用WebRTC搭建前端視頻天室——信令

    摘要:使用能使得狀態(tài)被保存在服務(wù)器上會話描述協(xié)議將客戶端之間傳遞的信令分為兩種信令和信令。他們主要內(nèi)容的格式都遵循會話描述協(xié)議,簡稱。 博客原文地址 建議看這篇之前先看一下使用WebRTC搭建前端視頻聊天室——入門篇 如果需要搭建實例的話可以參照SkyRTC-demo:github地址 其中使用了兩個庫:SkyRTC(github地址)和SkyRTC-client(github地址) ...

    sixgo 評論0 收藏0
  • WebRTC對點網(wǎng)絡(luò)通信機制

    摘要:本質(zhì)上允許網(wǎng)頁程序創(chuàng)建點對點通信,我們將會在隨后的章節(jié)中進行介紹。信令涉及網(wǎng)絡(luò)檢索和穿透,會話創(chuàng)建及管理,通信安全,媒體功能元數(shù)據(jù)和調(diào)制及錯誤處理。這樣就會完全建立及激活節(jié)點間的網(wǎng)絡(luò)套接字會話。 原文請查閱這里,略有刪減,本文采用知識共享署名 4.0 國際許可協(xié)議共享,BY Troland。 這是 JavaScript 工作原理第十八章。 概述 何為 WebRTC ?首先,字面上已經(jīng)...

    Rango 評論0 收藏0

發(fā)表評論

0條評論

xuweijian

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<