WebRTC是一个免费的源项目,它通过简单的API为浏览器和移动应用程序提供实时通信功能。本文将向你展示WebRTC的基本概念和功能,并指导你使用Node.js构建自己的WebRTC视频应用。 先决条件:…
WebRTC是一个免费的开源项目,它通过简单的API为浏览器和移动应用程序提供实时通信功能。本文将向你展示WebRTC的基本概念和功能,并指导你使用Node.js构建自己的WebRTC视频应用。
先决条件
具有Java经验
掌握Socket.io基本知识
WebRTC基础
WebRTC支持在网络世界中进行实时通信,主要用于在网络上传输视频和音频数据。 在开始编写代码之前,我们首先来看一下WebRTC的最重要概念。
信令:
WebRTC用于浏览器中的通信流,但还需要一种机制来协调通信并发送控制消息,该过程称为信令。
令用于以下任务:
初始化和关闭通讯
与外界共享网络配置(IP地址,端口)
报告连接错误
信令方法不是WebRTC指定的,开发人员可以自行选择(本教程将使用Socket.io)。
STUN和TURN服务器
如果主要的WebRTC对等连接遇到问题,则将STUN和TURN服务器用作备用方法。 STUN服务器用于获取计算机的IP地址,而TURN服务器用作对等连接失败的中继。
既然我们已经了解了WebRTC的基本概念,就可以继续开发上面讨论的项目。
使用Socket.io发出信号
在使用WebRTC通过对等连接发送视频广播之前,我们首先需要使用信令方法(在本例中为Socket.IO)实例化该连接。
为此,我们创建项目并使用npm安装所需的依赖项:
mkdir WebSocketsVideoBroadcast && cd WebSocketsVideoBroadcast
npm install express socket.io –save
之后,我们创建以下文件夹结构:

我们从一个简单的Socket.io服务器框架开始:
1 | const express = require("express"); |
1 | const port = 4000; |
1 | const http = require("http"); |
1 | const io = require("socket.io")(server); |
1 | io.sockets.on("error", e => console.log(e)); |
然后,我们需要实现客户端和直播者与服务器的连接。 直播者的Socket ID保存到一个变量中,以便我们以后知道客户端需要连接到的位置。
1 | let broadcaster |
1 | io.sockets.on("connection", socket => { |
之后,我们将实现socket.io事件以初始化WebRTC连接。 双方将使用这些事件来实例化对等连接。
1 | socket.on("offer", (id, message) => { |
这就是我们Socket.io的服务器实现的全部内容,现在我们可以继续进行布局以及双方通信的实现。
Layouts
我们的布局由两个基本HTML文件组成,其中包含一个视频视图(稍后将显示我们正在发送的视频流)和一个CSS文件(用于某些基本样式)。
index.html文件包含一个视频视图,该视图将显示来自广播公司的视频流。 它还会导入socket.io依赖项和我们的watch.js文件。
1 |
|
broadcast.html文件与主布局非常相似,但会导入broadcast.js文件而不是watch.js。
1 | <title>Broadcaster</title> |
我还为视频视图提供了一些简单的CSS样式。
1 | html { |
}
1 | video { |
}
1 | body { |
}
RTCPeerConnection
RTCPeerConnections帮助我们将位于本地网络中的两台计算机相互连接。 在谈论这些类型的连接时,会涉及到很多术语:
ICE-互联网连接建立
1 | STUN-通过网络地址转换器[NAT]进行的用户数据报协议[UDP]的会话遍历 |
由于当今大多数设备都在NAT路由器后面,因此无法直接连接。 这就是为什么必须由STUN服务器初始化对等连接的原因,STUN服务器将返回我们可以连接的ICE候选对象。
在本指南中,我们有两个不同的连接部分。 一个是视频直播方,可以与客户端建立多个对等连接,并使用流发送视频。 第二个是客户端,它与当前视频直播方只有一个连接。
直播方
首先,我们为对等连接和摄像机创建配置对象。
1 | const peerConnections = {}; |
{
1 | urls: ["stun:stun.l.google.com:19302"] |
}
]
};
1 | const socket = io.connect(window.location.origin); |
1 | // Media contrains |
1 | const constraints = { |
};
们用正式的google STUN服务器进行点对点连接,并使用媒体限制条件配置摄像机。 你也可以通过取消注释音频线路来启用音频。
在创建对等连接之前,我们首先需要从摄像机获取视频,以便将其添加到我们的连接中。
navigator.mediaDevices
1 | .getUserMedia(constraints) |
})
1 | .catch(error => console.error(error)); |
接下来,我们将使用以下代码创建一个RTCPeerConnection:
1 | socket.on("watcher", id => { |
1 | let stream = video.srcObject; |
1 | peerConnection.onicecandidate = event => { |
}
};
peerConnection
1 | .createOffer() |
1 | socket.on("answer", (id, description) => { |
1 | socket.on("candidate", (id, candidate) => { |
每次有新客户端加入时,我们都会创建一个新的RTCPeerConnection并将其保存在我们的peerConnections对象中。
然后,我们使用addTrack()方法将本地流添加到连接中,并传递流和跟踪数据。
当我们收到一个ICE候选者时,将调用peerConnection.onicecandidate事件,并将其发送到我们的服务器。
之后,我们通过调用peerConnection.createOffer()将连接提议发送给客户端,然后调用peerConnection.setLocalDescription()来配置连接。
当客户端断开连接时,关闭连接是应用程序的另一个重要部分,我们可以使用以下代码来实现:
1 | socket.on("disconnectPeer", id => { |
最后,如果用户关闭窗口,我们将关闭socket连接。
1 | window.onunload = window.onbeforeunload = () => { |
};
客户端
客户端(观看视频的一方))具有几乎相同的功能。 唯一的区别是,他仅打开了与当前视频直播方的一个对等连接,并且他获取了视频,而不是流式传输视频。
我们还需要为RTCPeerConnection创建一个配置。
1 | let peerConnection; |
{
}
]
};
然后,我们可以创建我们的RTCPeerConnection并从视频直播方获取视频流。
1 | socket.on("offer", (id, description) => { |
};
}
};
1 | }); |
在这里,我们像上面一样使用配置对象创建了一个新的RTCPeerConnection。 唯一的区别是,我们调用createAnswer()函数将连接应答发送回视频直播方的请求。
建立连接后,我们可以继续使用peerConnection对象的ontrack事件侦听器获取视频流。
我们还需要为点对点连接实现其他生命周期功能,这将有助于我们打开和关闭新连接。
1 | .addIceCandidate(new RTCIceCandidate(candidate)) |
1 | socket.on("connect", () => { |
1 | }); |
1 | peerConnection.close(); |
};
至此,该应用程序已完成,可以继续在浏览器中对其进行测试。
测试应用程序
现在我们已经完成了该应用程序,是时候对其进行测试,看看它是否可以工作了。
我们可以使用以下命令启动该应用程序:
node server.js
该应用程序现在应该在你的localhost:4000上运行,并且可以通过连接到localhost:4000 / broadcast来添加新的视频直播品程序进行测试。
之后,只需要访问localhost:4000即可作为客户端连接到服务器,并且你应该获得从视频直播方的流式传输的视频。
结论
我希望本文能帮助您了解WebRTC的基础知识以及如何使用它来流式传输视频直播。
EasyRTC视频会议云服务
基于WebRTC技术而开发的EasyRTC,是TSINGSEE青犀视频团队在音视频领域多年的技术积累而研发的, 它是覆盖全球的实时音频开发平台,支持一对一、一对多等视频通话。
EasyRTC拥有MCU和SFU两种架构,无需安装客户端与插件,纯H5在线视频会议系统,支持微信小程序、H5页面、APP、PC客户端等接入方式,极大满足语音视频社交、在线教育和培训、视频会议和远程医疗等场景需求。
随着移动互联网的高速发展,AI、5G等等新兴技术的到来,结合WebRTC技术,也将衍生出更多的应用场景,改变人类的衣、食、住、行等生活方式。
本文标题: 如何使用Javascript构建WebRTC
发布时间: 2022年02月12日 00:00
最后更新: 2025年12月30日 08:54
原始链接: https://haoxiang.eu.org/36bd08b4/
版权声明: 本文著作权归作者所有,均采用CC BY-NC-SA 4.0许可协议,转载请注明出处!

