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.pswp.cn/diannao/70433.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/70433.shtml
英文地址,請注明出處:http://en.pswp.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;使你更加適應高級…