UNIAPP开发之利用阿里RTC服务实现音视频通话后端THINKPHP5

下面是一个使用ThinkPHP 5实现后端逻辑的示例。我们将创建一个简单的ThinkPHP 5项目来处理生成推流和播流地址的请求。

后端部分(ThinkPHP 5)

1. 初始化ThinkPHP 5项目

首先,确保你已经安装了Composer。然后使用Composer创建一个新的ThinkPHP 5项目。

composer create-project topthink/think tp5-rtc-demo
cd tp5-rtc-demo
2. 安装依赖

ThinkPHP 5自带了一些必要的依赖,我们还需要安装guzzlehttp/guzzle来处理HTTP请求。

composer require guzzlehttp/guzzle
3. 创建控制器

application/index/controller目录下创建一个新的控制器文件Rtc.php

<?php
namespace app\index\controller;use think\Controller;
use GuzzleHttp\Client;class Rtc extends Controller
{// 阿里云RTC的AppID和AppKeyprivate $appId = 'your_app_id';private $appKey = 'your_app_key';// 生成Token的函数private function generateToken($userId, $channelName){$timestamp = time() + 3600; // 1小时有效期$nonce = bin2hex(random_bytes(15));$signature = hash_hmac('sha1', $this->appId . $channelName . $userId . $timestamp . $nonce, $this->appKey);return '0001' . $this->appId . $channelName . $userId . $timestamp . $nonce . $signature;}// 处理获取推流和播流地址的请求public function getRtcToken(){$userId = input('post.userId');$otherUserId = input('post.otherUserId');$channelName = 'room1'; // 可以根据需要动态生成房间名$token = $this->generateToken($userId, $channelName);$pushUrl = "wss://your-rtc-push-url/{$channelName}?token={$token}";$playUrl = "wss://your-rtc-play-url/{$channelName}?token={$token}";return json(['pushUrl' => $pushUrl, 'playUrl' => $playUrl]);}
}
4. 配置路由

route/route.php中添加路由规则。

use think\Route;Route::post('get-rtc-token', 'index/Rtc/getRtcToken');
5. 启动ThinkPHP 5服务器

在项目根目录下启动ThinkPHP 5内置服务器。

php think run

默认情况下,服务器会在http://localhost:8000上运行。

前端部分

前端部分与之前的示例保持一致,只需将后端URL改为ThinkPHP 5的地址。

1. 编写前端代码

pages/index/index.vue中编写以下代码:

<template><view><!-- 本地视频预览 --><live-pusher :url="pushUrl" mode="RTC" autopush @statechange="onPushStateChange"></live-pusher><!-- 远程视频播放 --><live-player :src="playUrl" mode="RTC" autoplay @statechange="onPlayStateChange"></live-player></view>
</template><script>
export default {data() {return {pushUrl: '',playUrl: '',};},methods: {onPushStateChange(e) {console.log('推流状态变化', e);},onPlayStateChange(e) {console.log('播放状态变化', e);},// 获取推流和播流地址的逻辑async getRTCToken() {const response = await uni.request({url: 'http://localhost:8000/get-rtc-token',method: 'POST',data: {userId: 'user1',otherUserId: 'user2',},});this.pushUrl = response.data.pushUrl;this.playUrl = response.data.playUrl;},},onLoad() {this.getRTCToken();},
};
</script><style>
/* 添加一些样式 */
live-pusher, live-player {width: 100%;height: 300px;
}
</style>

运行项目

  1. 启动后端服务器
php think run
  1. 启动UniApp项目

在HBuilderX中打开你的UniApp项目,然后点击运行按钮,选择合适的模拟器或真机进行测试。

注意事项

  1. 阿里云RTC的URL格式

    • 上述示例中的pushUrlplayUrl是示例格式,你需要根据阿里云RTC的实际文档来调整URL格式。
    • 确保你已经正确配置了阿里云RTC的推流和播流地址。
  2. 安全性

    • 在生产环境中,确保你的后端服务和Token生成逻辑是安全的,防止未授权访问。
  3. 网络环境

    • 测试时,请确保网络环境稳定,以获得更好的音视频通话体验。

通过以上步骤,你应该能够实现一个基本的UniApp音视频通话功能,并使用ThinkPHP 5作为后端来处理音视频流。如果有任何问题或需要进一步的帮助,请随时提问。


同样我们可以更完善一下前端的代码例如增加上开始通话和结束通话的功能

<template><view class="container"><view class="video-container"><!-- 本地视频预览 --><live-pusherref="livePusher":url="pushUrl"mode="RTC"autopush@statechange="onPushStateChange"class="live-pusher"></live-pusher><!-- 远程视频播放 --><live-playerref="livePlayer":src="playUrl"mode="RTC"autoplay@statechange="onPlayStateChange"class="live-player"></live-player></view><view class="controls"><button @click="startCall" :disabled="isCalling" class="control-button">开始通话</button><button @click="endCall" :disabled="!isCalling" class="control-button">结束通话</button></view></view>
</template><script>
export default {data() {return {pushUrl: '',playUrl: '',isCalling: false,};},methods: {onPushStateChange(e) {console.log('推流状态变化', e);},onPlayStateChange(e) {console.log('播放状态变化', e);},// 获取推流和播流地址的逻辑async getRTCToken() {const response = await uni.request({url: 'http://localhost:8000/get-rtc-token',method: 'POST',data: {userId: 'user1',otherUserId: 'user2',},});this.pushUrl = response.data.pushUrl;this.playUrl = response.data.playUrl;},startCall() {this.$refs.livePusher.start();this.$refs.livePlayer.play();this.isCalling = true;},endCall() {this.$refs.livePusher.stop();this.$refs.livePlayer.stop();this.isCalling = false;},},onLoad() {this.getRTCToken();},
};
</script><style>
/* 添加一些样式 */
.container {display: flex;flex-direction: column;align-items: center;justify-content: center;height: 100vh;background-color: #f0f0f0;
}.video-container {display: flex;flex-direction: row;justify-content: space-around;width: 100%;max-width: 800px;margin-bottom: 20px;
}.live-pusher, .live-player {width: 45%;height: 300px;border: 1px solid #ccc;border-radius: 10px;overflow: hidden;
}.controls {display: flex;flex-direction: row;justify-content: space-around;width: 100%;max-width: 400px;
}.control-button {padding: 10px 20px;font-size: 16px;color: #fff;background-color: #007aff;border: none;border-radius: 5px;cursor: pointer;
}.control-button:disabled {background-color: #ccc;cursor: not-allowed;
}
</style>

总而言之是需要大家去一步步的实践的。如果有更好的实现方式请分享反馈给我们

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/70433.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

嵌入式开发岗位认识

目录 1.核心定义2.岗位方向3.行业方向4.技术方向5.工作职责6.核心技能7.等级标准8.优势与劣势9.市场薪资10. 发展路径11. 市场趋势12. 技术趋势 1.核心定义 嵌入式系统&#xff1a; 以应用为中心&#xff0c;以计算机技术为基础&#xff0c;软硬件可裁剪的专用计算机系统 特点…

图解循环神经网络(RNN)

目录 1.循环神经网络介绍 2.网络结构 3.结构分类 4.模型工作原理 5.模型工作示例 6.总结 1.循环神经网络介绍 RNN&#xff08;Recurrent Neural Network&#xff0c;循环神经网络&#xff09;是一种专门用于处理序列数据的神经网络结构。与传统的神经网络不同&#xff0c…

MySQL数据库入门到大蛇尚硅谷宋红康老师笔记 高级篇 part 2

第02章_MySQL的数据目录 1. MySQL8的主要目录结构 1.1 数据库文件的存放路径 MySQL数据库文件的存放路径&#xff1a;/var/lib/mysql/ MySQL服务器程序在启动时会到文件系统的某个目录下加载一些文件&#xff0c;之后在运行过程中产生的数据也都会存储到这个目录下的某些文件…

http 响应码影响 video 标签播放视频

背景 使用后端给的文件下载接口地址实现视频播放&#xff0c;但是 video 标签一直无法播放视频如下图&#xff0c;把接口地址放到浏览器请求能直接下载。但就是不能播放 原因 http 响应码不正确&#xff0c;返回201是无法播放视频200可以如下图 状态码的影响&#xff1a; 20…

OneNote手机/平板“更多笔记本”中有许多已经删掉或改名的,如何删除

问题描述&#xff1a; OneNote 在手机或平板上添加“更多笔记本”中&#xff0c;有许多已经删掉或改名的笔记本&#xff01;如何删除&#xff1f; OR&#xff1a;如何彻底删除OneNote中的笔记本&#xff1f; 处理做法&#xff1a; 这个列表对应365里面的【最近打开】&#…

LeetCode--23. 合并 K 个升序链表【堆和分治】

23. 合并 K 个升序链表 给你一个链表数组&#xff0c;每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中&#xff0c;返回合并后的链表。 正文 这道题有多种解决方案 堆 比较容易&#xff0c;又比较直观的就是堆排序&#xff0c;将每个节点加入最小根堆中&…

【 Avalonia UI 语言国际化 I18n】图文结合教学,保姆级教学,语言国际化就是这么简单(.Net C#)

完整项目地址 github : https://github.com/Crazy-GrowUp/AvaloniaI18nTest/tree/master gitee :https://gitee.com/jack_of_disco/avalonia-i18n-test 0.项目新建 Properties 文件夹 对应的项目配置文件里面就会增加 <Folder Include"Properties\" /> 1.项…

点击el-dialog弹框跳到其他页面浏览器的滚动条消失了多了 el-popup-parent--hidden

点击el-dialog弹框跳到其他页面浏览器的滚动条消失了 在使用 el-dialog 弹框时&#xff0c;Element Plus 会在弹框打开时自动给 body 添加 el-popup-parent–hidden 类&#xff0c;以隐藏滚动条。如果在跳转到其他页面时滚动条没有恢复&#xff0c;可能是因为 el-dialog 没有正…

JWT认证机制

Session认证机制中需要配合cookie才能实现&#xff0c;由于cookie默认不支持跨域访问&#xff0c;当涉及到前端跨域请求后端接口时&#xff0c;需要做很多额外的配置&#xff0c;才能实现跨域session认证。所以这里不推荐使用session身份认证机制&#xff0c;一般推荐使用jwt认…

netcore 启用gzip压缩及缓存

public void ConfigureServices(IServiceCollection services) {....// 配置gzip 与 br的压缩等级为最优services.Configure<BrotliCompressionProviderOptions>(options > {options.Level CompressionLevel.Optimal;});services.Configure<GzipCompressionProvid…

qt:常见标签操作,倒计时功能,进度条与日历

1.标签常见函数 函数功能void setext(const QString &text)设置文本QString text()const获取文本void setPixmap(const QPixmap)与Pixmap()const设置和获取图像void setAlignment(Qt::Alignment alignment)设置对齐&#xff08;获取和上面一样&#xff09;void setWordWr…

STM32MP157A单片机移植Linux驱动

在stm32mp157a单片机移植Linux操作系统&#xff0c;并移植内核驱动&#xff0c;在应用程序中使用3个线程&#xff0c;分别实现控制单片机上3个led流水灯的功能、蜂鸣器控制的功能、风扇控制的功能。 需求整理&#xff1a; 1.驱动程序-->led1.c&#xff0c;led2.c&#xff…

python中格式化输出知识点汇总

在Python中&#xff0c;格式化输出是一种常见的操作&#xff0c;用于将数据以特定的格式展示。以下是Python中格式化输出的主要方法&#xff1a; ### 1. 使用 % 操作符 这是Python早期版本中常用的格式化方法&#xff0c;类似于C语言中的printf。 - **基本语法**&#xff1a;&…

完美转发使用

完美转发的几个例子 例子 1&#xff1a;普通的完美转发 首先&#xff0c;我们先来一个简单的完美转发的例子&#xff0c;展示如何使用 std::forward 来保持传入参数的类型。 #include <iostream> #include <utility> // std::forwardvoid func(int& x) {st…

【Content-Type详解、Postman中binary格式、json格式数据转原始二进制流等】

Content-Type详解、Postman中binary格式、json格式数据转原始二进制流等 背景&#xff1a;postman中如何使用binary格式上传文件 Content-TypeContent-Type的格式由三部分组成&#xff1a;以下是一些常见的Content-Type示例&#xff1a; Postman中 binary格式定义&#xff1a;用…

DeepSeek等大模型功能集成到WPS中的详细步骤

记录下将**DeepSeek功能集成到WPS中**的步骤&#xff0c;以备忘。 1. 下载并安装OfficeAI插件 访问OfficeAI插件下载地址&#xff1a;https://www.office-ai.cn/&#xff0c;下载插件&#xff08;目前只支持windows系统&#xff09;。 注意&#xff0c;有两个插件&#xff0…

MATLAB学习之旅:从入门到基础实践

在当今科技飞速发展的时代,MATLAB作为一款强大的数学软件,犹如一把神奇的钥匙,能够打开众多领域的大门。无论是工程计算、数据分析,还是算法开发、可视化呈现,MATLAB都展现出了无与伦比的魅力。今天,就让我们踏上这段奇妙的MATLAB学习之旅,从最基础的部分开始,逐步探索…

在Ubutu18.04下搭建nfs服务器

在Ubutu18.04下搭建nfs服务器 主要参考这篇博客 Ubuntu18.04下安装NFS详细步骤_乌班图安装nfs-CSDN博客 1.安装NFS服务&#xff1a; 服务器端&#xff1a; sudo apt install nfs-kernel-server

栈,优先级队列,map,set

文章目录 栈题目解析代码 优先级队列题解代码 map题解代码 set题解代码 栈 题目解析 1.先把元素push进栈中&#xff0c;如果栈非空并且栈中的元素按顺序和k相等就出栈&#xff0c;直到栈为空或者k ! sk.top() 代码 #include<iostream> #include<stack> #include&l…

C++ Primer 类的静态成员

欢迎阅读我的 【CPrimer】专栏 专栏简介&#xff1a;本专栏主要面向C初学者&#xff0c;解释C的一些基本概念和基础语言特性&#xff0c;涉及C标准库的用法&#xff0c;面向对象特性&#xff0c;泛型特性高级用法。通过使用标准库中定义的抽象设施&#xff0c;使你更加适应高级…