当前位置: 首页 > wzjs >正文

政务内网网站建设方案博客推广工具

政务内网网站建设方案,博客推广工具,公司给别人做的网站违法吗,支持企业网站发布要怎么做文章目录 前言WebRTC 的 ICE candidate 协商1. 什么是 ICE candidate?2. ICE 协商的流程3.前端使用 ICE candidate 协商代码示例1)收集 candidate 并发送2)WebSocket 接收 candidate 并添加 4. ICE candidate 的类型5. ICE 协商常见问题6. 关…

文章目录

  • 前言
  • WebRTC 的 ICE candidate 协商
    • 1. 什么是 ICE candidate?
    • 2. ICE 协商的流程
    • 3.前端使用 ICE candidate 协商代码示例
      • 1)收集 candidate 并发送
      • 2)WebSocket 接收 candidate 并添加
    • 4. ICE candidate 的类型
    • 5. ICE 协商常见问题
    • 6. 关键调试点
    • 7. 代码片段加日志示例
    • 总结


前言

WebRTC 的 ICE candidate 协商

WebRTC 的 ICE candidate 协商


1. 什么是 ICE candidate?

  • ICE(Interactive Connectivity Establishment) 是 WebRTC 用于 NAT 穿透、建立点对点连接的核心协议。
  • candidate(候选地址)是指本地网络环境下所有可能的可用地址(如本地IP、公网IP、中继服务器IP等)。
  • 通过收集和交换 candidate,WebRTC 能找到一条可用的网络路径,实现端到端音视频传输。

2. ICE 协商的流程

  1. 双方创建 RTCPeerConnection,并设置 ICE 服务器(通常是 STUN/TURN)。
  2. 本地收集 candidate:浏览器会自动收集本地所有可用的网络地址(candidate)。
  3. onicecandidate 事件触发:每收集到一个 candidate,就通过信令服务器发送给对端。
  4. 对端收到 candidate,通过 addIceCandidate 添加到自己的 RTCPeerConnection。
  5. 双方不断交换 candidate,直到找到一条可用的网络路径,ICE 连接建立,媒体流就能传输了。

3.前端使用 ICE candidate 协商代码示例

1)收集 candidate 并发送

 const pc = new RTCPeerConnection({iceServers: [// 免费的公共 STUN 服务,适用于测试和轻量级应用{ urls: "stun:stun.l.google.com:19302" },],})
pc.onicecandidate = (e) => {if (e.candidate) {ws.send(JSON.stringify({ type: "candidate", candidate: e.candidate }))}
}
  • 每当本地收集到一个 candidate,就通过 WebSocket 发送给对方。

    RTCPeerConnection ,截图自MDN。

在这里插入图片描述

2)WebSocket 接收 candidate 并添加

前端可以用 ws 这个库。

 ws.onmessage = async (msg) => {if (data.type === "candidate") {try {await pc.addIceCandidate(data.candidate)} catch (e) {}}} 
  • 收到对方的 candidate 后,调用 addIceCandidate 添加到本地 RTCPeerConnection。

4. ICE candidate 的类型

  • host:本地局域网 IP 地址
  • srflx:服务器反射地址(通过 STUN 服务器获取的公网 IP)
  • relay:中继地址(通过 TURN 服务器获取,适合复杂 NAT/防火墙环境)

5. ICE 协商常见问题

  • 没有 candidate 交换:双方无法建立连接,媒体流无法传输。
  • addIceCandidate 报错:SDP 协商顺序不对,或 candidate 格式有误。
  • NAT/防火墙阻断:需要配置 TURN 服务器。
  • 局域网可通,公网不通:STUN 只能穿透部分 NAT,复杂网络需 TURN。

6. 关键调试点

  • onicecandidateaddIceCandidate 前后加日志,确认 candidate 是否收发完整。
  • 检查 candidate 的类型和内容,确认是否有 srflxrelay 类型。
  • 浏览器控制台查看 ICE 相关报错(如 ICE failed、addIceCandidate failed 等)。

7. 代码片段加日志示例

pc.onicecandidate = (e) => {if (e.candidate) {console.log('Send ICE candidate:', e.candidate);ws.send(JSON.stringify({ type: "candidate", candidate: e.candidate }))}
}else if (data.type === "candidate") {console.log('Receive ICE candidate:', data.candidate);try {await pc.addIceCandidate(data.candidate)} catch (e) {console.error('addIceCandidate error', e);}
}

总结

  • ICE candidate 协商是 WebRTC 能否连通的关键,决定了媒体流能否端到端传输。
http://www.dtcms.com/wzjs/286320.html

相关文章:

  • 临沭有做网站的吗电商网络营销
  • 单页网站QQ空间2022年适合小学生的新闻
  • 台州市住房和城乡建设局网站如何规划企业网络推广方案
  • 沧州网站建设王宝祥汕头seo网站推广
  • 网上做设计网站seo怎么优化排名
  • 企业开发网站建设东莞有限公司seo
  • 学做蛋糕什么网站查图百度识图
  • 建设银行手机绑定网站优化网站排名技巧
  • 有什么好的网站查做外贸出口的企业关键词分类工具
  • 顺德医疗网站建设杭州网站关键词排名
  • 新区快速seo排名太原自动seo
  • 网站建设网站徒手整形培训山东企业网站建设
  • 怎样学习做网站的编程免费注册域名网站
  • 什么是品牌网站网站流量监控
  • 网站建设的公司地址品牌广告图片
  • 网站高端设计公司百度网盘下载电脑版官方下载
  • 做海报的专业网站网络优化工程师工资
  • 网站建设 连云港网络广告文案范文
  • 崇礼网站建设广州专业网络推广公司
  • 做seo怎么设计网站游戏推广合作
  • 长尾网站搜索引擎12月30日疫情最新消息
  • 做外贸公司网站广告推广怎么做
  • 网站建设 排名宝下拉人工在线客服
  • 北京网站seo排名优化百度在线识别图片
  • 做网站兼容性怎么设置怎么线上推广自己的产品
  • 建设银行网站打不开其他网站可以退吗在线网页制作系统搭建
  • 青海网站建设 小程序开发搜索指数查询
  • 有关网站升级建设的申请书长沙seo推广外包
  • 宁波高端网站建设bt最佳磁力搜索引擎吧
  • 诚聘高新网站开发工程师合肥网站优化排名推广