nginx + php + mysql直播管理-權限鑒定

背景

前一篇文章中已經完成了基本環境的搭建,以及實現了簡單的推流和播放功能,但是這里我們需要的是有權限的用戶才能進行推流,并不是所用的用戶都能夠進行推流,這里我們就需要做權限鑒定。

權限鑒定

  • 權限鑒定的第一步是需要一個用戶體系,然后我這里在數據庫建立了一個簡單的用戶信息表,包含用戶的name,pwd,roomid;這里的roomid是方便用戶后期開啟直播的時候使用。


    用戶信息表
  • 用戶創建直播房間,用戶傳入用戶名和密碼進行房間的創建。
$user_sql = "select * from live_user_t where name = '" . $name . "' and pwd = '".$pass."'";

$con = DBConnection::getConnect();

//檢查用戶名是否存在
$result = $con->query($user_sql);
$b = $result->num_rows == 0 ? false : true;
if ($b){
    //從用戶表里面獲取roomid
    $roomId = $result->fetch_assoc()['roomid'];
    $t_sql = "select * from live_room_t where roomid='%s';";
    $t_sql = sprintf($t_sql,$roomId);
    $b = $con->query($t_sql)->num_rows == 0 ? true : false;
    if ($b){
        $uuid = Util::md5($roomId);
        //生成驗證碼
        $checkCode = Util::md5($name.$pass.$uuid.time());
        //生成直播地址
        $pushUrl = PushUrl.$roomId.'?code='.$checkCode;
        //生成播放地址
        $liveUrl = LiveUrl.$roomId;
        //生成m3u8播放地址
        $hlsurl = HlsUrl.$roomId.'.m3u8';
        $room_sql = "insert into live_room_t values('%s','%s','%s','%s','%s','%s',0,0,NOW(),NOW());";
        $result = $con->query(sprintf($room_sql,$uuid,$roomId,$pushUrl,$liveUrl,$hlsurl,$checkCode));
        if ($result) {
            print_r(responseDataStructure::responseDataAndCloseDB(200,'創建房間成功',
                array(
                    'roomId'=>$roomId,
                    'roomPushUrl'=>$pushUrl,
                    'roomLiveUrl'=>$liveUrl,
                    'roomHlsUrl'=>$hlsurl,
                    'roomCount'=>0,
                    'roomStatus'=>0
                ),$con));
        } else {
            print_r(responseDataStructure::responseDataAndCloseDB(400, '創建房間失敗', array(), $con));
        }
    }else{
        print_r(responseDataStructure::responseDataAndCloseDB(400, '房間已存在!', array(), $con));
    }
}else{
    print_r(responseDataStructure::responseDataAndCloseDB(400,'用戶名或密碼錯誤!',array(),$con));
}
  • 根據返回的直播地址進行推流,當進行推流的時候會走Nginx配置文件里面的推流通知,如圖:


    推流通知
  • 在接收推流通知的處理文件里面我們把checkCode取出來進行鑒定,如果checkCode不正確,就不允許用戶推流,這樣就實現了沒有經過權限鑒定的用戶不允許推流。

    @$data = file_get_contents("php://input");
    $roomId = Util::convertUrlQuery($data)['name'];
    $code = Util::convertUrlQuery($data)['code'];

    if (empty($code)){
        header('HTTP/1.1 403 Forbidden');
        header('Status: 403 Forbidden');
        return;
    }

    $sql = "select * from live_room_t where roomcheckcode = '" . $code . "' and roomid='".$roomId."';";

    $con = DBConnection::getConnect();
    //檢查code
    $b = count($con->query($sql)->fetch_all()) == 0 ? false : true;
    if (!$b){
        $con->close();
        header('HTTP/1.1 403 Forbidden');
        header('Status: 403 Forbidden');
        return;
    }

    echo '推流連接成功';

    if(!empty($roomId)){
        $sql = "update live_room_t set roomstatus = 1,updatetime = now() where roomid = '".$roomId."'";
        $result = $con->query($sql);
        if ($result) {
            print_r(responseDataStructure::responseDataAndCloseDB(200,'更新直播狀態成功', array(), $con));
        } else {
            print_r(responseDataStructure::responseDataAndCloseDB(400, '更新直播狀態失敗',array(), $con));
        }
    }

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容