成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

webRTC 初探

klinson / 3058人閱讀

摘要:如果要多人會話,就要單對單建立多個連接。同樣的步驟執(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í)行多次就可以了

客戶端代碼 html



  
  Title




js
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

相關(guān)文章

  • WebRTC 初探

    摘要:雖然是點對點通信,但還是需要服務(wù)器來初始化連接,并傳遞一些信息。服務(wù)器實現(xiàn)點對點通信的關(guān)鍵在于兩個瀏覽器之間能直接發(fā)送和接收數(shù)據(jù)包,但一般情況下,瀏覽器或手機都是通過路由器訪問,所以存在網(wǎng)絡(luò)地址轉(zhuǎn)換。 WebRTC 瀏覽器本身不支持相互之間直接建立信道進行通信,都是通過服務(wù)器進行中轉(zhuǎn)。比如現(xiàn)在有兩個客戶端,甲和乙,他們倆想要通信,首先需要甲和服務(wù)器、乙和服務(wù)器之間建立信道。甲給乙發(fā)送消...

    williamwen1986 評論0 收藏0
  • Hola~ 一款基于Electron的聊天軟件

    摘要:前言本項目旨在從零到壹,制作一款界面精美的聊天軟件。因為本人是開發(fā),設(shè)計功底欠缺,所以軟件設(shè)計的有點丑,如果有大神有更好的,歡迎。 Hola 前言 本項目旨在從零到壹,制作一款界面精美的聊天軟件。 Github 地址因為已工作,所以可能沒有多少時間來繼續(xù)跟進這個項目了,項目可優(yōu)化的點已在下文列出,歡迎大家 Fork 或 Star。 ps: 征 logo 一枚。因為本人是開發(fā),設(shè)計功底...

    Kaede 評論0 收藏0
  • WebRTC入門教程(三) | Android 端如何使用 WebRTC

    摘要:下面我們就看一下具體如何申請權(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的整體流程,在熟悉了整體流程之后,...

    番茄西紅柿 評論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條評論

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