摘要:如果要多人會話,就要單對單建立多個連接。同樣的步驟執(zhí)行多次就可以了客戶端代碼開始結(jié)束發(fā)送打開頁面即開啟等待模式服務(wù)端代碼
webRTC介紹
webRTC是英文Web Real-Time Communication的縮寫,中文翻譯網(wǎng)頁實時通信,是瀏覽器不需要服務(wù)器的中轉(zhuǎn),可以直接通信的技術(shù)
webRTC 應(yīng)用網(wǎng)上的很多教程都會包含實時視頻的介紹,不過我感覺視頻看起來很酷,不過卻不是webRTC的使用難點,卻明顯增加webRTC的使用復(fù)雜度,可以略過
webRTC是客戶端對客戶端的單對單實時通信,但是還是需要服務(wù)器,就好比一個婚介所的作用
下面我們通過socket.io作為服務(wù)器端實現(xiàn)簡單的聊天功能
實現(xiàn)步驟
發(fā)起方向服務(wù)器發(fā)出通知并初始化RTCPeerConnection
服務(wù)器接收到通知通知接收并初始化RTCPeerConnection
雙方都監(jiān)聽onicecandidate事件,并在回調(diào)里面把event.candidate上傳到服務(wù)器
雙發(fā)都監(jiān)聽ondatachannel事件,并在回調(diào)里面給event.channel監(jiān)聽onmessage事件
發(fā)起方調(diào)用createOffer方法,并在這個方法的回調(diào)中給自己的RTCPeerConnection實例設(shè)置setLocalDescription,并向服務(wù)器發(fā)送自己的Description
接收方在服務(wù)器推送給自己的消息里面把5中的Description設(shè)置為自己的RTCPeerConnection實例的RemoteDescription,并調(diào)用createAnswer方法,在此方法的回調(diào)之中設(shè)置setLocalDescription,并把自己的Description上傳到服務(wù)器
發(fā)起方接收到服務(wù)器推送給自己的Description,設(shè)置為LocalDescription,至此雙方連接建立
雙方可以調(diào)用自己的channel的send方法發(fā)送文本消息
至于調(diào)用視頻和音頻,我覺著這部分使用起來比較簡單,不繞
步驟就是一方的開啟視頻,獲取視頻流,添加到RTCPeerConnection實例中,連接的另外一方監(jiān)聽onaddstream事件,獲取視頻流,OK
多人會話的話,同一個RTCPeerConnection實例是不能夠多人會話的。如果要多人會話,就要單對單建立多個連接。同樣的步驟執(zhí)行多次就可以了
客戶端代碼 htmlTitle
var video = document.getElementById("video") var localPeerConnection, remotePeerConnection var localChannel var socket = io.connect("http://localhost:8181") // 打開頁面即開啟等待模式 startWaiting() function startWaiting() { var servers = { "iceServers": [{ "url": "stun:stun.l.google.com:19302" }] } var pc_constraints = { optional: [{ DtlsSrtpKeyAgreement: true }] } localPeerConnection = new RTCPeerConnection(servers, pc_constraints) localChannel = localPeerConnection.createDataChannel("sendDataChannel", { reliable: true }) localPeerConnection.onicecandidate = function(event) { if (event.candidate) { socket.emit("onicecandidate", event.candidate) } } localChannel.onopen = function() { console.log("open") } localChannel.onclose = function() { console.log("close") } localPeerConnection.ondatachannel = function(event) { console.log(event.channel) event.channel.onmessage = function(msg) { console.log("event msg", msg) } } socket.on("offer", function(desc) { console.log("offer: ", desc) localPeerConnection.setRemoteDescription(desc) setRemote = true localPeerConnection.createAnswer(function(desc) { localPeerConnection.setLocalDescription(desc) socket.emit("answer", desc) }, function(error){console.log(error)}) }) socket.on("answer", function(desc) { console.log("answer: ", desc) localPeerConnection.setRemoteDescription(desc) console.log("answer end") setRemote = true }) socket.on("onicecandidate", function(icecandidate) { localPeerConnection.addIceCandidate(icecandidate) }) } document.getElementById("start").onclick = function() { localPeerConnection.createOffer(function(desc) { localPeerConnection.setLocalDescription(desc) socket.emit("offer", desc) }, function(error){console.log(error)}) } document.getElementById("send").onclick = function() { var value = document.getElementById("textarea").value localChannel.send(value) }服務(wù)端代碼
var static = require("node-static") var http = require("http") var file = new(static.Server)() var app = http.createServer(function (req, res) { file.serve(req, res); }).listen(8181); var io = require("socket.io").listen(app) io.sockets.on("connection", function(socket) { socket.on("offer",function(desc) { socket.broadcast.emit("offer", desc) }) socket.on("answer",function(desc) { socket.broadcast.emit("answer", desc) }) socket.on("onicecandidate", function(candidate) { socket.broadcast.emit("onicecandidate", candidate) }) socket.on("message", function(message) { socket.broadcast.to(message.channel).emit("message", message.message) }) })
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/82720.html
摘要:雖然是點對點通信,但還是需要服務(wù)器來初始化連接,并傳遞一些信息。服務(wù)器實現(xiàn)點對點通信的關(guān)鍵在于兩個瀏覽器之間能直接發(fā)送和接收數(shù)據(jù)包,但一般情況下,瀏覽器或手機都是通過路由器訪問,所以存在網(wǎng)絡(luò)地址轉(zhuǎn)換。 WebRTC 瀏覽器本身不支持相互之間直接建立信道進行通信,都是通過服務(wù)器進行中轉(zhuǎn)。比如現(xiàn)在有兩個客戶端,甲和乙,他們倆想要通信,首先需要甲和服務(wù)器、乙和服務(wù)器之間建立信道。甲給乙發(fā)送消...
摘要:前言本項目旨在從零到壹,制作一款界面精美的聊天軟件。因為本人是開發(fā),設(shè)計功底欠缺,所以軟件設(shè)計的有點丑,如果有大神有更好的,歡迎。 Hola 前言 本項目旨在從零到壹,制作一款界面精美的聊天軟件。 Github 地址因為已工作,所以可能沒有多少時間來繼續(xù)跟進這個項目了,項目可優(yōu)化的點已在下文列出,歡迎大家 Fork 或 Star。 ps: 征 logo 一枚。因為本人是開發(fā),設(shè)計功底...
摘要:下面我們就看一下具體如何申請權(quán)限靜態(tài)權(quán)限申請在項目中的中增加以下代碼動態(tài)權(quán)限申請隨著的發(fā)展,對安全性要求越來越高。其定義如下通過上面的代碼我們就將顯示視頻的定義好了。當(dāng)發(fā)送消息,并收到服務(wù)端的后,其狀態(tài)變?yōu)椤?作者:李超,如遇到相關(guān)問題,可以點擊這里與作者直接交流。 前言 在學(xué)習(xí) WebRTC 的過程中,學(xué)習(xí)的一個基本步驟是先通過 JS 學(xué)習(xí) WebRTC的整體流程,在熟悉了整體流程之后,...
摘要:本質(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)...
閱讀 2719·2021-11-11 16:54
閱讀 2338·2021-10-09 09:44
閱讀 2565·2019-08-30 15:54
閱讀 1945·2019-08-30 11:24
閱讀 1187·2019-08-29 17:03
閱讀 2115·2019-08-29 16:22
閱讀 2095·2019-08-29 13:11
閱讀 1056·2019-08-29 12:14