0

0

如何利用WebRTC在浏览器中实现点对点的实时通信?

夜晨

夜晨

发布时间:2025-09-24 18:59:01

|

852人浏览过

|

来源于php中文网

原创

答案:通过WebRTC实现浏览器间实时通信需三步:先用getUserMedia获取本地音视频流并预览;再创建RTCPeerConnection实例,添加流并配置STUN服务器;最后通过信令服务器交换SDP和ICE候选,完成连接后即可传输媒体流。

如何利用webrtc在浏览器中实现点对点的实时通信?

要在浏览器中通过WebRTC实现点对点的实时通信,核心在于建立两个浏览器之间的直接连接,无需经过服务器传输音视频流。整个过程依赖信令交换、网络协商和媒体流传输三个关键步骤。

1. 获取本地媒体流

首先需要获取用户的摄像头和麦克风权限,生成本地媒体流。

navigator.mediaDevices.getUserMedia() 方法用于请求访问音频和视频设备。

示例代码:

const localStream = await navigator.mediaDevices.getUserMedia({
  video: true,
  audio: true
});
document.getElementById('localVideo').srcObject = localStream;

获取到的媒体流可以绑定到页面的 video 元素进行预览。

2. 创建RTCPeerConnection并添加流

RTCPeerConnection 是 WebRTC 的核心类,负责处理点对点连接。

创建实例后,需将本地媒体流添加进去:

const peerConnection = new RTCPeerConnection({
  iceServers: [{ urls: 'stun:stun.l.google.com:19302' }]
});

localStream.getTracks().forEach(track => {
  peerConnection.addTrack(track, localStream);
});

STUN 服务器帮助获取公网 IP 和端口(NAT 穿透),若在复杂网络环境下可考虑加入 TURN 服务器作为中继备份。

3. 信令机制交换会话描述

WebRTC 不提供内置信令传输方式,需自行实现客户端之间的消息传递(如使用 WebSocket)。

通信流程如下:

AI at Meta
AI at Meta

Facebook 旗下的AI研究平台

下载
  • 发起方调用 createOffer() 生成本地 offer 描述
  • 设置本地描述:setLocalDescription(offer)
  • 将 offer 发送给对方(通过 WebSocket 或其他通道)
  • 接收方收到 offer 后,调用 setRemoteDescription() 设置远端描述
  • 接收方生成 answer:createAnswer() 并设置为本地描述
  • 将 answer 发回给发起方

这样双方就完成了 SDP(会话描述协议)的交换。

4. ICE 候选地址交换

在连接过程中,浏览器会收集可用的网络路径(IP+端口),称为 ICE 候选。

通过监听 onicecandidate 事件获取候选,并发送给对方:

peerConnection.onicecandidate = event => {
  if (event.candidate) {
    // 将 candidate 发送给对方
    socket.emit('ice-candidate', event.candidate);
  }
};

对方收到后调用 addIceCandidate() 添加到连接中:

peerConnection.addIceCandidate(new RTCIceCandidate(candidate));

当所有候选完成交换,且 NAT 穿透成功,点对点连接即建立。

连接建立后,远程媒体流会通过 ontrack 事件传入:

peerConnection.ontrack = event => {
  document.getElementById('remoteVideo').srcObject = event.streams[0];
};

基本上就这些。只要信令通路正确、网络环境支持,WebRTC 能在几秒内建立起低延迟的音视频通话。关键是理解 SDP 协商与 ICE 候选交换的配合逻辑,不复杂但容易忽略细节。

相关专题

更多
Golang WebSocket与实时通信开发
Golang WebSocket与实时通信开发

本专题系统讲解 Golang 在 WebSocket 开发中的应用,涵盖 WebSocket 协议、连接管理、消息推送、心跳机制、群聊功能与广播系统的实现。通过构建实际的聊天应用或实时数据推送系统,帮助开发者掌握 如何使用 Golang 构建高效、可靠的实时通信系统,提高并发处理与系统的可扩展性。

20

2025.12.22

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

84

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

24

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

35

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

16

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

56

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

16

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

9

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
webrtc/swoole实战音视频直播项目
webrtc/swoole实战音视频直播项目

共22课时 | 1.6万人学习

PHP课程
PHP课程

共137课时 | 8.8万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号