我正在嘗試開發一個使用webRTC和WebSockets進行信號傳輸的視頻聊天應用程序。 我的問題是,我不知道創建RTCPeerConnection的過程是什麼,並通過webSocket(至少本地)連接兩個對等體(2個瀏覽器)。我知道如何通過WebSockets與客戶端進行通信,但不知道如何與RTCPeerConnection API進行通信,你知道任何教程一步一步解釋過程?(提供SDP,答案,ICE,...),另一方面,另一方面那麼如何通過RTCPeerConnection查看服務器代碼來管理這些客戶端呢?通過Websockets的WebRTC視頻聊天
這裏是
"use strict";
// Optional. You will see this name in eg. 'ps' or 'top' command
process.title = 'node-webrtc';
// Port where we'll run the websocket server
var webSocketsServerPort = 1337;
// websocket and http servers
var webSocketServer = require('websocket').server;
var http = require('http');
/* ---------------------------------
GLOBAL VARIABLES
----------------------------------*/
// latest 100 messages
//var history = [ ];
// list of currently connected clients (users)
var clients = [ ];
/* ---------------------------------
HTTP SERVER
----------------------------------*/
var server = http.createServer(function(request, response) {
// Not important for us. We're writing WebSocket server, not HTTP server
});
server.listen(webSocketsServerPort, function() {
console.log((new Date()) + " Server is listening on port " + webSocketsServerPort);
});
/* ---------------------------------
WEBSOCKET SERVER
----------------------------------*/
var wsServer = new webSocketServer({
// WebSocket server is tied to a HTTP server. WebSocket request is just
// an enhanced HTTP request. For more info http://tools.ietf.org/html/rfc6455#page-6
httpServer: server
});
// This callback function is called every time someone
// tries to connect to the WebSocket server
wsServer.on('request', function(request) {
console.log((new Date()) + ' Connection from origin ' + request.origin + '.');
// accept connection - you should check 'request.origin' to make sure that
// client is connecting from your website
// (http://en.wikipedia.org/wiki/Same_origin_policy)
var connection = request.accept(null, request.origin);
// we need to know client index to remove them on 'close' event
var index = clients.push(connection) - 1;
console.log((new Date()) + ' Connection accepted.');
// user sent some message
connection.on('message', function(message) {
for (var i=0; i < clients.length; i++) {
clients[i].sendUTF(message);
}
});
// user disconnected
connection.on('close', function(conn) {
console.log((new Date()) + " Peer " + conn.remoteAddress + " disconnected.");
// remove user from the list of connected clients
clients.splice(index, 1);
});
});
謝謝AeroBuffalo,這就是我正在尋找的東西:)現在,我將理解代碼並製作我自己的代碼。 – user2402604
感謝您指出這個項目。設置示例網站很簡單。過去一週我一直在使用socket.io,websocket.io,RTCMultiConnection和RTCPeerConnection,但WebRTC.io正是我想要的。 –