极简 WebRTC 入门(非文档版,简洁易懂)

对于前端开发者来说,想要实现网页端实时音视频通信,WebRTC 绝对是绕不开的技术。它不用插件、原生支持,能快速实现点对点通信,今天就用最简单的方式,带你入门,附带实用代码实例,上手更轻松。

一、什么是 WebRTC

WebRTC(Web Real-Time Communication),简单说就是浏览器原生支持的实时通信技术,由谷歌开源、W3C 标准化,主流浏览器(Chrome、Edge、Safari 等)都能直接用,不用装任何插件,核心是实现网页端点对点(P2P)的音视频、数据传输。

二、WebRTC 能做什么

全是需要 "实时互动" 的场景,比如:网页端视频 / 语音通话、直播连麦、屏幕共享、在线教育、P2P 文件传输,不用服务器中转,效率更高。

三、核心 API 简单介绍(附代码实例)

WebRTC 核心就 3 个 JS API,不用死记,会用简单代码就行:

  1. getUserMedia(访问设备):调用摄像头、麦克风,获取音视频流
javascript 复制代码
// 调用摄像头、麦克风,获取音视频流
navigator.mediaDevices.getUserMedia({ video: true, audio: true })
  .then(stream => {
    // 将流渲染到页面视频标签
    const localVideo = document.getElementById('localVideo');
    localVideo.srcObject = stream;
  })
  .catch(err => console.error('无法访问设备:', err));
  1. RTCPeerConnection(核心连接):建立 P2P 连接,处理音视频传输
javascript 复制代码
// 初始化连接,使用谷歌公共 STUN 服务器(无需自己部署)
const peerConnection = new RTCPeerConnection({
  iceServers: [{ urls: 'stun:stun.l.google.com:19302' }]
});
// 添加本地流到连接
stream.getTracks().forEach(track => peerConnection.addTrack(track, stream));
  1. RTCDataChannel(传输数据):通过 P2P 传文字、文件等普通数据
javascript 复制代码
// 创建数据通道,发送/接收消息
const dataChannel = peerConnection.createDataChannel('chat');
dataChannel.onopen = () => dataChannel.send('连接成功!');
dataChannel.onmessage = (event) => console.log('收到消息:', event.data);

四、WebRTC 工作流程(极简版 + 代码)

核心 4 步,结合代码更易理解:

  1. 采集:用 getUserMedia 获取本地音视频流(代码如上);
  2. 信令:用 WebSocket 交换双方信息(简易客户端)
javascript 复制代码
// 连接信令服务器,发送/接收信息
const ws = new WebSocket('ws://localhost:8080');
ws.send(JSON.stringify({ type: 'offer', sdp: offerSdp }));
ws.onmessage = (event) => {
  const data = JSON.parse(event.data);
  // 处理对方的 SDP 和 ICE 信息
  if (data.type === 'answer') peerConnection.setRemoteDescription(new RTCSessionDescription(data));
  if (data.candidate) peerConnection.addIceCandidate(new RTCIceCandidate(data.candidate));
};
  1. 连接:用 RTCPeerConnection 建立 P2P 连接(代码如上);
  2. 通信:接收远端流,渲染到页面
javascript 复制代码
// 监听远端流,渲染到页面
peerConnection.ontrack = (event) => {
  const remoteVideo = document.getElementById('remoteVideo');
  remoteVideo.srcObject = event.streams[0];
};

五、必备组件:WebSocket、STUN/TURN

WebRTC 不能单打独斗,必须配合这两个组件:

  1. WebSocket:实现信令交换(简易 Node.js 服务器,用 ws 库)
javascript 复制代码
// 安装依赖:npm install ws
const WebSocket = require('ws');
const wss = new WebSocket.Server({ port: 8080 });
// 转发双方信息(简易版)
wss.on('connection', (ws) => {
  ws.on('message', (data) => {
    wss.clients.forEach(client => {
      if (client !== ws && client.readyState === WebSocket.OPEN) client.send(data);
    });
  });
});
  1. STUN/TURN 服务器:解决内网穿透,上文代码已用谷歌公共 STUN 服务器,无需自己部署;TURN 用于直连失败时中转。

六、优缺点 & 适用场景

  • 优点:浏览器原生支持、无需插件 < 100ms)、开源免费、跨平台;
  • 缺点:信令系统需自行开发、依赖 STUN/TURN 服务器、音视频质量受网络影响;
  • 适用场景:中小型实时互动(在线客服、一对一聊天、小型会议、直播连麦),大型场景需配合 SFU 服务器。
相关推荐
左左右右左右摇晃3 小时前
计算机网络笔记整理
笔记·计算机网络
不吃西红柿的853 小时前
[职场] 内容运营求职简历范文 #笔记#职场发展
笔记·职场和发展·内容运营
似水明俊德4 小时前
02-C#.Net-反射-学习笔记
开发语言·笔记·学习·c#·.net
智者知已应修善业4 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机
C羊驼4 小时前
C语言:两天打鱼,三天晒网
c语言·经验分享·笔记·算法·青少年编程
sheeta19985 小时前
苍穹外卖Day04笔记
笔记
今儿敲了吗8 小时前
46| FBI树
数据结构·c++·笔记·学习·算法
苦瓜小生9 小时前
【黑马点评学习笔记 | 实战篇 】| 6-Redis消息队列
redis·笔记·后端
sheeta199810 小时前
LeetCode 每日一题笔记 日期:2025.03.19 题目:3212.统计X和Y频数相等的子矩阵数量
笔记·leetcode·矩阵
巧克力味的桃子11 小时前
国名排序题笔记(字符串函数 + fgets 详解)
笔记