音视频项目——RTSP服务器解析(2)

介绍

利用EPOLL,实现 RTSP 服务器的高并发请求处理。 RTSP 是音视频的控制视频的协议,如果您还不了解,可以看看之前我解析 RTSP 协议的文章。音视频协议解析(RTP/RTCP/RTSP/RTMP)------RTSP解析-CSDN博客

解析

接着上文,我们继续解析 RTSP 服务器。

这篇文章解析 RTP 的函数。

rtpHeaderInit:
cpp 复制代码
#include<sys/socket.h>
#include<arpa/inet.h>
#include<cstdlib>
#include<string>
#include "rtp.h"

void rtpHeaderInit(RtpPacket* rtpPacket, uint8_t csrcLen, uint8_t extension,
                   uint8_t padding, uint8_t version, uint8_t payloadType, uint8_t marker,
                   uint16_t seq, uint32_t timestamp, uint32_t ssrc){
                
    rtpPacket->rtpHeader.csrcLen = csrcLen;
    rtpPacket->rtpHeader.extension = extension;
    rtpPacket->rtpHeader.padding = padding;
    rtpPacket->rtpHeader.version = version;
    rtpPacket->rtpHeader.payloadType = payloadType;
    rtpPacket->rtpHeader.marker = marker;
    rtpPacket->rtpHeader.seq = seq;
    rtpPacket->rtpHeader.timestamp = timestamp;
    rtpPacket->rtpHeader.ssrc = ssrc;
}

这是初始化 RTP 的 Header 函数。给 RTP 的一系列进行赋值。

rtspSendPacketOverTcp:
cpp 复制代码
int rtspSendPacketOverTcp(int clientSockfd, RtpPacket* rtpPacket, uint32_t dataSize, char channel){
    rtpPacket->rtpHeader.seq = htons(rtpPacket->rtpHeader.seq);
    rtpPacket->rtpHeader.timestamp = htonl(rtpPacket->rtpHeader.timestamp);
    rtpPacket->rtpHeader.ssrc = htonl(rtpPacket->rtpHeader.ssrc);

    uint32_t rtpSize = RTP_HEADER_SIZE + dataSize;
    char* temBuf = new char[rtpSize + 4];
    temBuf[0] = 0X24;
    temBuf[1] = channel;
    temBuf[2] = (uint8_t)((rtpSize & 0xFF00) >> 8);
    temBuf[3] = (uint8_t)(rtpSize & 0xFF);
    memcpy(temBuf + 4, (char*)rtpPacket, rtpSize);

    int ret = send(clientSockfd, temBuf, rtpSize + 4, 0);

    rtpPacket->rtpHeader.seq = ntohs(rtpPacket->rtpHeader.seq);
    rtpPacket->rtpHeader.timestamp = ntohl(rtpPacket->rtpHeader.timestamp);
    rtpPacket->rtpHeader.ssrc = ntohl(rtpPacket->rtpHeader.ssrc);

    delete [] temBuf;
    return ret;
}

这是通过 TCP 发送包(packet)的函数。

首先,给包的头部(Header)的 seq,timestamp,ssrc 进行转换,htons 和 htols 都是把主机字节序转换为网络字节序的函数,用于网络转发。

然后,就是要通过 send 发送数据了。

cpp 复制代码
int send(int socket, const void *buffer, size_t length, int flags);

我们发送的是 temBuf 数组,length 是 RTP_HEADER_SIZE + 4,是因为要在 temBuf 数组头部加上 0x24,channel,(rtpSize & 0xFF00) >> 8,rtpSize & 0xFF 的信息。

最后,将 rtpPacket 的 Header 的信息转换为主机字节序,并释放 temBuf,返回 send 值。

好了,这篇文章解析到这里。

欲知后事如何,请听下回分解。

相关推荐
EasyDSS2 小时前
智能会议管理系统/私有化视频会议平台EasyDSS私有化部署构建企业级私域视频全场景解决方案
人工智能·音视频
潜创微科技5 小时前
切换器芯片主要型号有哪些:潜创微高清音视频领域主流型号与应用场景全解析
音视频
KevinCyao6 小时前
106视频短信接口怎么发?支持高清影音下发的106视频短信服务商
音视频
潜创微科技--高清音视频芯片方案开发7 小时前
2026年切换器方案服务商市场格局分析与主流品牌选型指南
音视频·硬件工程
潜创微科技--高清音视频芯片方案开发7 小时前
2026年高清音视频切换器方案选型分
音视频
二等饼干~za8986689 小时前
源码可控:云罗 GEO 源头工厂,开源搭建 + 二次开发全链路解决方案
服务器·开发语言·开源·php·音视频·ai-native
feasibility.10 小时前
OpenClaw+LibTV视频生成实测(含安装+配置+分析):ai生成工作流很规范,但画面在“打架“
人工智能·aigc·音视频·内容运营·短剧·openclaw·libtv
深念Y11 小时前
FFmpeg 480p 转码失败但 1080p/720p 正常的坑
ffmpeg·音视频·转码·流媒体·分辨率·hls·m3u8
不吃鱼的猫74813 小时前
【音视频流媒体进阶:从网络到 WebRTC】第04篇-流媒体场景下的网络优化
网络·音视频·webrtc
不吃鱼的猫74814 小时前
【音视频流媒体进阶:从网络到 WebRTC】第02篇-I/O 多路复用:从 select 到 epoll
网络·音视频·webrtc