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

介绍

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

解析

我们继续解析 RTSP 服务器函数。

上次还有个函数没解析完,我们看看

rtpSendPacketOverUdp:

本函数是用 UDP 协议发送数据包

cpp 复制代码
int rtspSendPacketOverUdp(int serverRtpSockfd, const char* ip, int16_t port, RtpPacket* rtpPacket, uint32_t dataSize){
    struct sockaddr_in addr;
    int ret;

    addr.sin_family = AF_INET;
    addr.sin_port = htons(port);
    addr.sin_addr.s_addr = inet_addr(ip);

    rtpPacket->rtpHeader.seq = htons(rtpPacket->rtpHeader.seq);
    rtpPacket->rtpHeader.timestamp = htonl(rtpPacket->rtpHeader.timestamp);
    rtpPacket->rtpHeader.ssrc = htonl(rtpPacket->rtpHeader.ssrc);

    ret = sentto(serverRtpSockfd, (char*)rtpPacket, RTP_HEADER_SIZE + dataSize, 0, (struct sockaddr*)&addr, sizeof(addr));

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

    return ret;
}

sockaddr_in addr,是我们的目标套接字。

将 rtpPacket 的 Header 的 seq,timestamp,ssrc 转换为网络字节序,便于发送,运用 htons 与 htons 函数。

cpp 复制代码
ssize_t sendto(int sockfd, const void *buff, size_t nbytes, int flags, const struct sockaddr *to, socklen_t *addrlen);

sendto 基于 UDP 发送数据。

最后,ntohs,ntohl 将 rtpPacket 的 Header 重新转换为主机字节序,并返回 sendto 的结果。

好了,今天先将讲到这里。

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

相关推荐
进击的小头2 小时前
FIR滤波器实战:音频信号降噪
c语言·python·算法·音视频
Black蜡笔小新2 小时前
终结“监控盲区”:EasyGBS视频质量诊断技术多场景应用设计
人工智能·音视频·视频质量诊断
liliangcsdn5 小时前
视频嵌入表示生成方案的探索
数据库·人工智能·音视频
查无此人byebye5 小时前
深度解析:当前AI视频生成为何普遍“短小精悍”?
人工智能·pytorch·python·深度学习·音视频·transformer
买辣椒用券5 小时前
STM32F407音频采集与播放实战:INMP441麦克风与MAX98357A扬声器
stm32·嵌入式硬件·音视频
愚公搬代码6 小时前
【愚公系列】《AI短视频创作一本通》010-AI 短视频分镜头设计(分镜头设计的基本流程)
人工智能·音视频
共享家95276 小时前
基于 Coze 工作流搭建 AI 动物视频生成器
人工智能·音视频
前端世界7 小时前
在鸿蒙中实现实时语音与视频传输:架构思路 + 可跑 Demo 全解析
架构·音视频·harmonyos
xmRao7 小时前
Qt+SDL2 实现 WAV 音频播放
qt·音视频
向量引擎小橙7 小时前
万字硬核:从 3D VAE 到 DiT,深度解构 AI 视频生成的“时空建模”之殇与工程化突围
人工智能·3d·音视频