WebRTC,名称源自网页实时通信(Web Real-Time Communication)的缩写,是一个支持网页浏览器进行实时语音对话或视频对话的API。它于2011年6月1日开源并在Google、Mozilla基金会、Opera支持下被包括进万维网联盟的W3C推荐标准。
不需要插件的实时通信
想像一下,如果你的手机、电视、电脑都可以通过一个平台进行通信,想像一下你可以在Web应用中轻松地加入视频聊天和p2p数据分享,你还没有兴奋吗?这就是WebRTC。
想试一试吗?WebRTC现在已经被集成到Chrome,Opera和火狐上了,你可以试试这个应用:
-
在Chrome、Opera或Firefox中打开apprtc.appspot.com。
-
点击允许按钮允许应用使用你的摄像头。
-
在新的选项卡,甚至在另外一台电脑上打开正文显示的URL。
这里是这个应用的具体教程: later in this article。
开始
如果你没有时间阅读这个系列的文章,想直接编码,你可以这样:
-
你果你没有用过getUserMedia,要先学习一下它,教程:HTML5 Rocks article ,Demo:simpl.info/gum。
-
掌握RTCPeerConnection API,教程:simple example below ,Demo:simpl.info/pc,。
-
了解一下WebRTC的实现、防火墙和NAT转发,教程:apprtc.appspot.com.
-
webRTC使用大头照拍摄:gbtags.com/gb/share/2491.htm
或者你可以直接跳到这一步:在WebRTC codelab上一步一步的学习如何构建一个完整的视频聊天应用程序,包括一个简单的信号服务器。
关于WebRTC的小故事
其实一个Web开发的终极挑战就是通过音频和视频进行实时通信,视频通信应该像文本通信一样自然,如果没有它,我们在用户交互方面的创新能力会受到限制。
在过去,实时通信都比较复杂,需要非常丰富的音频和视频技术才能被进行开发。 完整的实现实时通信需要整合大量的数据和服务,在Web上实现尤其困难。
2008年,Gmail视频聊天火了。2011年谷歌发布了Hangouts,收购了GIPS,GIPS是一个RTC方向的公司,然后开源了它的相关技术,在同年5月,爱立信构建了 第一个WebRTC的实现。
Hangouts 是谷歌在2013年的Google I/O大会上发布了统一消息服务,整合了此前的Google Talk、Google+ Messenger和 Hangouts视频聊天服务等产品。新的Hangouts完全基于云计算技术,将成为谷歌其他服务的一大支柱。尽管谷歌在热门的移动消息应用市场动作较 慢,但谷歌正在为未来的发展做准备。从表面来看,Hangouts是类似WhatsApp和Facebook Messenger的又一款消息应用。
WebRTC目前用做实时通信、免费视频插件、音频和视频数据传输。以下是实际的应用:
-
很多Web服务已经使用了RTC,但是都需要下载插件或是原生app,比如Skype,Facebook和Google Hangouts。
-
下载安装更新插件非常麻烦。
-
插件不容易发现问题,测试很困难,大部分都需要授权,开发成本太高。
安全性
这里有几个实时通信应用可以出现的安全性问题:
-
未加密的媒体数据流可以会在浏览器或通信途中被获取。
-
应用可能会在用户不知情的情况下记录视频和其它信息。
-
恶意软件或病毒可能被安装在一个不起眼的插件或应用中。
WebRTC通过各种特性避免了这些问题:
-
对数据流和信号量进行编码加密。
-
。WebRTC 不是一个插件,可以运行在浏览器的沙箱中,组件不需要单独安装。
-
摄像头和手机必须通过严格的授权,只有在显示用户界面的时候才能调用。
关于WebRTC安全性的详细讨论不在本文的讲解范围内,如果你想了解更多这方面的问题,可以看一看IETF提供的 WebRTC Security Architecture。
开发者工具
-
跨浏览器的 interop notes
-
adapter.js 是一个JavaScript 的WebRTC适配, 由Google贡献,它可以解决浏览器差异化的规范的变化。
-
想了解更多WebRTC信号量,可以通过apprtc.appspot.com 查看输出日至。
-
Chrome bugsBug报告:crbug.com/new 。Opera:bugs.opera.com/wizard/ 。Firefox:bugzilla.mozilla.org。
在哪里使用WebRTC
WebRTC有以下三个API:
-
MediaStream (别名 getUserMedia)
getUserMedia 可以在Chrome, Opera 和 Firefox中实现。 你可以看看这个跨平台的Demo:simpl.info/gum 和Chris Wilson的 例子 ,让getUserMedia作为音频的输入。
RTCPeerConnection 是在Chrome中和Android设备中使用,经过几次迭代之后RTCPeerConnection现在支持 Chrome and Opera 作为webkitRTCPeerConnection,Firefox 作为mozRTCPeerConnection。
RTCDataChannel 支持Chrome 25, Opera 18 和Firefox 22 以上的版本。
通常有报道说一个平台支持WebRTC,一般都说他们支持getUserMedia,而不支持其它RTC组件,开发的时候需要先弄清楚。
我的第一个WebRTC项目
WebRTC 项目需要做以下几件事情:
-
取到音频、视频或其它数据的数据流。
-
得到网络信息,如IP地址和端口,通过网络和其它WebRTC客户端交换数据,解决防火墙的NAT转发的问题。
-
协调信号来报告错误,启动或关闭会话。
-
交换媒体和客户端信息,处理如分辨率和编码解码器问题。dia and client capability, such as resolution and codecs.
-
数据流通信。
为了实现数据流之间的通信,WebRTC实现了以下的接口:
-
MediaStream: 取得数据流,比如从摄像头和手机中获取。
-
RTCPeerConnection: 音频和视频通话,设备加密和带宽管理。
-
RTCDataChannel: 点对点通信。
相关推荐
《WebRTC音视频实时互动技术》大纲覆盖了WebRTC的核心技术和实践应用,旨在帮助读者深入理解这一实时通信技术。以下是对大纲中重要知识点的详细解释: 1. 音视频服务质量: - 带宽管理:为了确保高质量的音视频...
4. **WebRTC**:WebRTC(Web Real-Time Communication)是浏览器之间的实时通信技术,无需插件或额外的软件即可实现音频、视频和数据共享。在本项目中,WebRTC将用于处理视频和音频的捕获、编码、解码和传输,确保两...
首先,WebRTC(Web Real-Time Communication)是谷歌推出的一项开放标准,它允许浏览器之间进行音视频通信,无需借助任何插件或第三方软件。WebRTC的核心技术包括 getUserMedia API(获取本地媒体流),...
用户可以在浏览器中直接参与视频通话,得益于WebRTC的API,开发者可以轻松获取用户的摄像头和麦克风权限,并实现视频流的发送和接收。 后端则采用了Java和WebSocket技术。WebSocket是一种在客户端和服务器之间建立...
使用场景及目标:本研究适用于需要实现实时音视频通信的企业级应用,尤其是在疫情背景下减少物理接触的需求。目标是在确保安全性和低延迟的前提下,提高视频会议的用户体验和成本效益。 其他说明:文章不仅涵盖了...
WebRTC(Web Real-Time...通过深入学习和分析`WebRTCDemo`中的代码,开发者不仅可以理解WebRTC的工作原理,还能掌握如何在Android应用中集成实时音视频通信功能,为开发聊天、会议、在线教育等应用场景打下坚实的基础。
在本项目中,我们探索的是一个基于Vue.js前端框架、Node.js后端(利用socket.io进行信令传输)以及WebRTC技术实现的一对一视频通信的示例应用。这个demo涵盖了多个关键知识点,让我们逐一深入解析。 首先,**WebRTC...
WebRTC(Web Real-Time Communication)是一种开放的网络通信标准,允许在浏览器之间进行实时的音频、视频和数据共享,无需插件或额外的应用程序。它包括了三个主要组件:信令、媒体引擎和数据通道。在本文中,我们...
jspsip实现webrtc进行音视频通信demo jspsip实现webrtc进行音视频通信demo jspsip实现webrtc进行音视频通信demo jspsip实现webrtc进行音视频通信demo jspsip实现webrtc进行音视频通信demo
在Android平台上,WebRTC(Web Real-Time Communication)是一种强大的开源框架,用于实现浏览器和移动设备之间的实时通信,包括音视频通话、数据共享等功能。在这个场景中,我们将探讨如何使用WebRTC从SRS(Simple ...
本教程主要以WebRTC JavaScript API为例,使用WebRTC实现实时通信 1. 介绍WebRTC整体架构,WebRTC JavaScript API 2. 如何获取webcam摄像头音视频数据 3. WebRTC peer之间建联流程 4. 介绍WebRTC信令,使用socket.IO...
在本文中,我们将深入探讨如何使用Flutter和WebRTC技术实现在移动应用中进行桌面共享和视频通信。首先,让我们简要了解一下Flutter、Dart和WebRTC这三个关键概念。 Flutter是Google开发的一个开源UI工具包,用于...
webRTC技术的应用,通过启动浏览器调用设备的视频和音频流实现实时通信。
WEBRTC多人视频通话,可以支持多人视频通话,目前是三人的,因为视频通话的信令用到的是websocket,所以代码里面也放入了单独websocket通信的demo,解释也比较详细了,原来有一个列子是两人的,后面改成三人的,多人...