Webrtc本端发candidate给对端

1.什么时候发
  1. request 分支末尾调 pc->setLocalDescription()
  2. 库开始 ICE gathering,在收集过程中每当产生一条新的本地 candidate,就回调 onLocalCandidate 一次。
  3. lambda 里立刻组 JSON 并 emit_signaling_json,所以信令上会出现多条 type=candidate

时间顺序上:一般在 setLocalDescription 之后很快就会出现(先 PC state=1,srflx 那条 candidate);第一条 host 往往更早或几乎同时,取决于库枚举网卡的顺序。

第一条candidate和第二条candidate内容

第一次typ host ------ 本机网卡上的地址(如 192.168.6.221)。

第二次:typ srflx ------ 经 STUN 看到的 NAT 反射公网地址。

复制代码
<?xml version="1.0" encoding="UTF-8"?>
<signaling>
  <id>MBF672lwa7</id>
  <type>candidate</type>
  <candidate><![CDATA[candidate:1 1 UDP 2114977791 192.168.6.161 46924 typ host]]></candidate>
  <mid>cam-video</mid>
</signaling>
[17:14:54.779] [webrtc_ldc] PC state=1 peer=MBF672lwa7 
2026-05-14 17:14:54.840 WARN  [4544] [rtc::impl::IceTransport::LogCallback@390] juice: Send failed, errno=101
[17:14:55.030] [webrtc_ldc] signaling TX
<?xml version="1.0" encoding="UTF-8"?>
<signaling>
  <id>MBF672lwa7</id>
  <type>candidate</type>
  <candidate><![CDATA[candidate:2 1 UDP 1678769919 183.238.154.133 6313 typ srflx raddr 0.0.0.0 rport 0]]></candidate>
  <mid>cam-video</mid>
</signaling>

2.Candidate带什么信息

每条 candidate 消息里的有效载荷就是 JSON 里的字段,例如:

  • candidate:一整条 ICE candidate 字符串(协议、优先级、IP、端口、typ host / typ srflx 等)。
  • mid:这条候选对应 SDP 里哪条 m-line(你是 cam-video,即视频)。
  • id:会话里的 peer_id,对端用来知道是同一拨信令。

第一次:typ host ------ 本机网卡上的地址(如 192.168.x.x)。

第二次:typ srflx ------ 经 STUN 看到的 NAT 反射公网地址。

SDP 里后面 a=candidate:... 还会再带一遍(offer 里在 a=end-of-candidates 前也有这两行),属于 SDP 内嵌候选;单独发的那两次 JSON 是 Trickle ICE,让对端不必等整份 SDP就能先加候选。

相关推荐
肖爱Kun4 小时前
Webrtc本端和对端信令交互步骤
服务器·webrtc
肖爱Kun1 天前
Webrtc信令交互
服务器·webrtc
Fisher3Star3 天前
WebRTC Transport 两种创建方式的差异解析
webrtc
Fisher3Star3 天前
FFmpeg推流至Mediasoup全流程指南
webrtc
Fisher3Star3 天前
mediasoup 创建Router全流程详解
webrtc
声网3 天前
OpenAI 的 WebRTC 秘密架构:没有 SFU?没有问题!丨 Voice Agent 学习笔记
学习·架构·webrtc
HySpark7 天前
VAD 与流式 ASR 踩坑复盘及完整解决方案
webrtc·vad·离线语音转写·流式asr·qwen-asr·音频预处理
徐子元竟然被占了!!7 天前
WebRTC协议
webrtc
ZC跨境爬虫7 天前
跟着 MDN 学 HTML day_28:(使用选择器 API 在 DOM 树中进行选择与遍历)
前端·ui·html·音视频·webrtc