阿里云ARTC Web SDK是由阿里云提供的一套基于Web的实时通信开发工具。它允许开发者在Web应用中快速集成高质量的音视频通话功能、实时消息传递等实时互动功能。本文为您演示快速搭建属于自己的ARTC应用。
步骤一:开通应用
步骤二:获取应用ID和AppKey
成功开通应用后,在应用管理列表中找到该应用,单击操作栏中的管理按钮,进入基本信息页面,在该页面获取对应的应用ID和AppKey 。
步骤三:集成接入
集成SDK。
Script集成
在您的HTML页面引入SDK脚本。
<script src="https://g.alicdn.com/apsara-media-box/imp-web-rtc/6.12.3/aliyun-rtc-sdk.js"></script>
NPM集成
在您的项目中使用npm安装SDK。
npm install aliyun-rtc-sdk --save
初始化引擎。
// 以下两种引入方式二选一 // 当以 npm 包方式引入时执行 import AliRtcEngine from 'aliyun-rtc-sdk'; // 当以 Script 方式引入时执行 const AliRtcEngine = window.AliRtcEngine; // 检测环境 const checkResult = await AliRtcEngine.isSupported(); if (!checkResult.support) { // 当前环境不支持使用,提示用户更换或升级浏览器 } // 创建引擎实例,可以保存至全局变量中 const aliRtcEngine = AliRtcEngine.getInstance();
创建好AliRtcEngine实例后,需要监听、处理相关事件。
// 当前用户离开频道 aliRtcEngine.on('bye', (code) => { // code 为原因码,具体含义请查看 API 文档 console.log(`bye, code=${code}`); // 这里做您的处理业务,如退出通话页面等 }); // 监听远端用户上线 aliRtcEngine.on('remoteUserOnLineNotify', (userId, elapsed) => { console.log(`用户 ${userId} 加入频道,耗时 ${elapsed} 秒`); // 这里处理您的业务逻辑,如展示这个用户的模块 }); // 监听远端用户下线 aliRtcEngine.on('remoteUserOffLineNotify', (userId, reason) => { // reason 为原因码,具体含义请查看 API 文档 console.log(`用户 ${userId} 离开频道,原因码: ${reason}`); // 这里处理您的业务逻辑,如销毁这个用户的模块 }); // 监听远端流订阅变化 aliRtcEngine.on('videoSubscribeStateChanged', (userId, oldState, newState, interval, channelId) => { // oldState、newState 类型均为AliRtcSubscribeState,值包含 0(初始化)、1(未订阅)、2(订阅中)、3(已订阅) // interval 为两个状态之间的变化时间间隔,单位毫秒 console.log(`频道 ${channelId} 远端用户 ${userId} 订阅状态由 ${oldState} 变为 ${newState}`); // 这里处理观看远端流的逻辑 // 当 newState 变为 3 时可以通过 setRemoteViewConfig 播放远端流 // 当 newState 变为 1 时可以停止播放 }); // 监听鉴权信息过期 aliRtcEngine.on('authInfoExpired', () => { // 该回调触发代表鉴权信息已过期 // 需要重新获取 token 等数据,调用 refreshAuthInfo 接口更新鉴权数据 aliRtcEngine.refreshAuthInfo({ userId, token, timestamp }); }); // 监听用户鉴权信息即将过期 aliRtcEngine.on('authInfoWillExpire', () => { // 该回调在鉴权信息30秒前触发,收到该回调后应该及时更新鉴权信息 // 若想要继续在会中,需要重新获取 token 等数据,调用 joinChannel 重新入会 });
(可选)设置频道模式,默认通话模式。详细信息,请参见设置频道模式和用户角色。
// 设置频道模式,支持传入字符串 communication(通话模式)、interactive_live(互动模式) aliRtcEngine.setChannelProfile('interactive_live'); // 设置角色,互动模式时调用才生效 // 支持传入字符串 interactive(互动角色,允许推拉流)、live(观众角色,仅允许拉流) aliRtcEngine.setClientRole('interactive');
加入频道。Token计算方式参见Token鉴权,您可以按需选择单参数入会或者多参数入会的方案。
单参数入会
const userName = '测试用户1'; // 可以修改为您的用户名(支持中文) try { // fetchToken需要您来实现,从服务端获取Base64Token const base64Token = await fetchToken(); await aliRtcEngine.joinChannel(base64Token, userName); // 加入成功,继续执行其他操作 } catch (error) { // 加入失败 }
多参数入会
// 参考文档 Token 鉴权部分,从服务端或本地生成鉴权信息 // 注意:为了您的数据安全,任何情况下都不应该将带有 appKey 的 token 计算逻辑发布给用户 const appId = 'yourAppId'; // 从控制台获取 const appKey = 'yourAppKey'; // 从控制台获取,注意请勿在生产环境露出您的 AppKey const channelId = 'AliRtcDemo'; // 可以修改为您的频道ID(仅支持英文字母、数字) const userId = 'test1'; // 可以修改为您的用户ID(仅支持英文字母、数字) const userName = '测试用户1'; // 可以修改为您的用户名(支持中文) const timestamp = Math.floor(Date.now() / 1000) + 3600; // 一个小时后过期 try { const token = await generateToken(appId, appKey, channelId, userId, timestamp); // 加入频道,参数 token、nonce 等一般由服务端返回 await aliRtcEngine.joinChannel({ channelId, userId, appId, token, timestamp, }, userName); // 加入成功,继续执行其他操作 } catch (error) { // 加入失败 }
预览画面和推流。默认情况下,加入频道后将自动采集本地的音视频数据并推送至阿里云GRTN网络中。您可以参考以下方式预览您的本地画面。
在HTML代码中增加一个
id
为localPreviewer
的VIDEO元素。<video id="localPreviewer" muted style="display: block;width: 320px;height: 180px;background-color: black;" ></video>
通过
setLocalViewConfig
方法传入元素ID开启预览。// 第一个参数支持传入 HTMLVideoElement 或对应的元素 ID,传入 null 时停止预览 // 第二个参数支持传入 1 (预览相机流)、2(预览屏幕共享流) aliRtcEngine.setLocalViewConfig('localPreviewer', 1);
订阅远端音视频流。默认情况下,加入频道后将自动订阅其他主播用户的音视频流,若有音频流将自动播放,需要观看相机流、屏幕流,则需要通过
setRemoteViewConfig
接口开启。在HTML代码中增加一个
id
为remoteVideoContainer
的DIV元素作为容器。<div id="remoteVideoContainer"></div>
监听到远端视频流订阅变化后,若已订阅
setRemoteViewConfig
接口播放,若未订阅则移除。// 存储 Video 元素 const remoteVideoElMap = {}; // 远端容器元素 const remoteVideoContainer = document.querySelector('#remoteVideoContainer'); function removeRemoteVideo(userId) { const el = remoteVideoElMap[userId]; if (el) { aliRtcEngine.setRemoteViewConfig(null, userId, 1); el.pause(); remoteVideoContainer.removeChild(el); delete remoteVideoElMap[userId]; } } // 同第二步监听事件示例代码中 videoSubscribeStateChanged 示例 aliRtcEngine.on('videoSubscribeStateChanged', (userId, oldState, newState, interval, channelId) => { // oldState、newState 类型均为AliRtcSubscribeState,值包含 0(初始化)、1(未订阅)、2(订阅中)、3(已订阅) // interval 为两个状态之间的变化时间间隔,单位毫秒 console.log(`频道 ${channelId} 远端用户 ${userId} 订阅状态由 ${oldState} 变为 ${newState}`); // 处理示例 if (newState === 3) { const video = document.createElement('video'); video.autoplay = true; video.setAttribute('style', 'display: block;width: 320px;height: 180px;background-color: black;'); remoteVideoElMap[userId] = video; remoteVideoContainer.appendChild(video); // 第一个参数传入 HTMLVideoElement // 第二个参数传入远端用户 ID // 第三个参数支持传入 1 (预览相机流)、2(预览屏幕共享流) aliRtcEngine.setRemoteViewConfig(video, userId, 1); } else if (newState === 1) { removeRemoteVideo(userId); } });
结束流程。
// 停止本地预览 await aliRtcEngine.stopPreview(); // 离开频道 await aliRtcEngine.leaveChannel(); // 销毁实例 aliRtcEngine.destroy();
快速体验
前提条件
快速体验demo需要您的开发环境启动一个HTTP服务,如果您没有安装http-server
的npm包,可以先执行npm install --global http-server
指令全局安装。
步骤一:创建目录
创建一个demo文件夹,并按照下方文件目录结构创建好quick.html
、quick.js
两个文件。
- demo
- quick.html
- quick.js
步骤二:编辑quick.html
将下方代码复制到quick.html,并保存。
步骤三:编辑quick.js
将下方代码复制到quick.js,并将应用ID和AppKey粘贴至代码指定变量中保存。
步骤四:运行体验
在终端中进入demo文件夹,然后执行
http-server -p 8080
,启动一个HTTP服务。浏览器中新建标签页,访问
localhost:8080/quick.html
,在界面上填入频道ID和用户ID ,单击加入频道按钮。浏览器中再新建一个标签页,访问
localhost:8080/quick.html
,在界面上填入与上一步相同的频道ID和另一个用户ID ,单击加入频道按钮。界面上将自动订阅另一个用户的媒体流。