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

介绍

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

解析

我们先来看 RTP 的实现。RTP 是音视频协议中负责传输数据的协议。

cpp 复制代码
#include<stdint.h>

#define RTP_VERSION             2
#define RTP_PAYLOAD_TYPE_H264   96
#define RTP_PAYLOAD_TYPE_AAC    97
#define RTP_HEADER_SIZE         12
#define RTP_MAX_PKT_SIZE        1400

class RtpHeader{
public:
    uint8_t csrcLen;    // 4 bits
    uint8_t extension;  // 1 bit
    uint8_t padding;    // 1 bit
    uint8_t version;    // 2 bit
    uint8_t payloadType; // 7 bits 
    uint8_t marker;     // 1 bit
    uint16_t seq;       
    uint32_t timestamp;
    uint32_t ssrc;
};

class RtpPacket{
public:
   RtpHeader rtpHeader;
   uint8_t payload[0];
};

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);

int rtspSendPacketOverTcp(int clientSockfd, RtpPacket* rtpPacket, uint32_t dataSize, char channel);

int rtspSendPacketOverUdp(int serverRtpSockfd, const char* ip, int16_t port, RtpPacket* rtpPacket, uint32_t dataSize);
RtpHeader:RTP 数据包的头部

csrclen:提供信源长度

extension:扩展标志,占 1 bits,如果X=1,则在RTP报头后跟有一个扩展报头

padding:填充标志,占1位,如果P=1,则在该报文的尾部填充一个或多个额外的八位组, 它们不是有效载荷的一部分

version:版本号,占 2 bits

payloadType:载荷类型

marker:标志,占 1 bits,不同的有效载荷有不同的含义,对于视频,标记一帧的结束;对于

音频,标记会话的开始。

seq:占 16bits,用于标识发送者所发送的RTP报文的序列号

timestamp:时间戳,占 32 bits,反映了该RTP报文的第一个八位组的采样时刻

ssrc:同步信源

RtpPacket:RTP 数据包

rtpheader:数据包头部

payload:载荷

好了,RTP 的包头部和包(packet),我们解析了。剩下的函数,我们下一回再解析。

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

相关推荐
技术砖家--Felix4 小时前
Spring Boot入门篇:快速搭建你的第一个Spring Boot应用
java·开发语言·音视频
fxshy6 小时前
python使用ffmpeg对视频进行转码
python·ffmpeg·音视频
zhangzhangkeji9 小时前
FFMPEG - 6:合并、提取音视频;截取、连接音视频,
ffmpeg·音视频
aqi0016 小时前
FFmpeg开发笔记(八十七)采用Kotlin的手机开源播放器VLC-Android
android·ffmpeg·音视频·流媒体
GalaxySpaceX20 小时前
STM32-音频播放
stm32·嵌入式硬件·音视频
Black蜡笔小新1 天前
赋能智慧货运:视频汇聚平台EasyCVR打造货运汽车安全互联网视频监控与管理方案
网络·汽车·音视频
撬动未来的支点1 天前
【音视频】DASH 和 SRT协议与传统协议对比
音视频
音视频牛哥1 天前
狂飙与重构:机器人IPO浪潮背后的系统焦虑与感知进化
人工智能·计算机视觉·机器人·音视频·多智能体协同·rtsp播放器rtmp播放器·视频感知低延迟音视频
撬动未来的支点1 天前
【音视频】SDP与SIP协议的区别与联系
音视频
EasyGBS1 天前
EasyGBS在智慧仓储物流场景下视频实时监控系统应用方案
网络·音视频