RTSP作为客户端 推流 拉流的过程分析

之前写过一个 rtsp server 作为服务端的简单demo

这次分析下 rtsp作为客户端 推流和拉流时候的过

A.作为客户端拉流 TCP方式

1.Client发送OPTIONS方法 Server回应告诉支持的方法

2.Client发送DESCRIPE方法 这里是从海康摄像机拉流并且设置了用户名密码 Server回复未认证

3.客户端通过服务器回复的realm nonce 计算response 重新带认证信息的DESCRIBE报文

服务器回复

4.客户端发送SETUP报文

5.客户端发送 PLAY报文

RTSP交互的过程如上

实际测试中发现 几点需要注意:

a.需要用户密码的 大多数是在发送DESCRIBE方法后返回401 有的是第一次发送OPTIONS方法就会返回401

b.服务端包含视频流 音频流 必须单独发送一次SETUP视频流 再发送一次SETUP音频流 我本来想只要视频流 不要音频流 但是实测发现不行 必须 视频流 音频流都SETUP

c.最后发送play报文之后 server回复报文的时候大多数时候 会将rtp报文连带一起发过来

需要做切割

需要用户名密码时候的认证信息计算 大多数都是走DIGEST方式 仅仅介绍此种方式

首先计算loginhash 计算方法为 MD5(username:realm:password) 之后转换为字符串

然后针对method和uri计算method_hash MD5(method:uri)

需要注意的是:SETUP时候的uri 和其他方法的uri是不一样的

最后计算response = MD5(MD5(loginhash:nonce):method_hash) 如下图

整个过程中 loginhash只需要计算一次既可 别的 每次都要计算

由于是tcp方式 和RTSP RTP RTCP 共用一个端口 后面 解析数据包即可

不管是rtp包还是rtcp包 前面有一个四个字节的头

首字节固定0x24 后面一个字节channel 区分 音视频 rtp rtcp 一般偶数通道标识rtp包 奇数标识rtcp包 后面两个字节表示包长

0x24 channel datalen

但是实际测试中发现 部分rtsp server tcp方式发送的时候 rtcp包没有这四个字节 找0x24头的时候找不到 ffmpeg会将错误原因设置为End of file 如下图 80 C8 00 06 是RTCP的报文

在我自己的测试程序中 可以直接跳过这个包 直接继续接受数据处理 即可 发现也没问题 采用ffmpeg的话 就只能更改ffmpeg源码了 会比较麻烦

以上是作为客户端拉流的时候

2.RTSP作为客户端推流 这里 采用ffmpeg推流rtsp 默认UDP方式 server采用ZLMediakit 分析

客户端发送OPTIONS方法 服务端回复支持的方法 可以看到比一般的摄像头多了ANNOUNCE RECORD方法

客户端发送ANNOUNCE方法

客户端发送SETUP方法

客户端发送RECORD方法

相关推荐
风翼靓崽30 分钟前
linux命令杂记 - 杂乱无章
linux·运维·服务器
xixixi7777737 分钟前
全模态原生大脑降临:GPT-5.5(Spud)发布,推理/编码提升30%,百万上下文+原生电脑控制,开启Agent新纪元
大数据·网络·人工智能·gpt·安全·电脑·量子计算
solihawk39 分钟前
服务器内存被谁“偷”走了?
服务器·数据库
我爱C编程1 小时前
基于WSN无线传感器网络的定向步幻影路由算法matlab仿真
网络·matlab·无线传感器网络·wsn·定向步幻影路由
域中四大1 小时前
rk3568中修改波特率
linux·运维
互联网推荐官1 小时前
大模型应用开发的上下文工程与推理链路深度拆解
大数据·运维·人工智能
风曦Kisaki1 小时前
# Linux Shell 编程入门 Day01:Shell 基础认知、脚本编写规范、变量四大类型、数值运算
linux·运维·chrome
德彪稳坐倒骑驴1 小时前
SQL连续登录问题
服务器·数据库·sql
云智慧AIOps社区1 小时前
云智慧亮相第二十八届智能体驱动的GOPS全球运维大会2026 · 深圳站!以运维智能体 Castrel AI (SRE Agent)保障系统稳定可靠!
运维·人工智能·ai agent·运维自动化·sre 智能体
校羽干1 小时前
ubuntu22.04 安装卸载更新 ollama
运维·服务器