我的问题是,我正在使用没有身份验证、基本身份验证和摘要身份验证三种方式来发起RTSP请求,具体取决于我想要访问的摄像机。这个方法已经运行良好一段时间了,但最近,在使用摘要身份验证时,出现了以下错误:
* Trying 127.0.0.1:8554...
* TCP_NODELAY set
* Connected to 127.0.0.1 (127.0.0.1) port 8554 (#0)
* Server auth using Digest with user 'ubnt'
> DESCRIBE rtsp://ubnt:administrator@127.0.0.1:8554/live.sdp RTSP/1.0
CSeq: 1
Accept: application/sdp
< RTSP/1.0 401 Unauthorized
< CSeq: 1
< WWW-Authenticate: Digest realm="GStreamer RTSP Server", nonce="3034e78651e4e61e"
< Server: GStreamer RTSP server
< Date: Sun, 12 Jan 2020 09:36:53 GMT
<
* Connection #0 to host 127.0.0.1 left intact
* Issue another request to this URL: 'rtsp://ubnt:administrator@127.0.0.1:8554/live.sdp'
* Protocol "rtsp" not supported or disabled in libcurl
* Closing connection -1
当我在同一台摄像机上切换到基本身份验证时,不会出现任何“Protocol“rtsp”not supported or disabled in libcurl”错误,而DESCRIBE/SETUP请求也按预期工作。
起初我认为问题出在我的代码上(我在go程序中使用libcurl绑定进行curl请求),但事实证明即使回滚到使用数字签名认证的第一个提交,问题仍无法解决。
我最初怀疑较新版本的libcurl存在漏洞,但目前尚无法确认。
有没有人知道我的问题可能是什么原因? 我应该向libcurl邮件列表发送电子邮件以解决这个问题吗?
更多信息的资源:
- 我遇到此问题的存储库
- 我使用的golang libcurl绑定
- PR介绍数字签名认证支持,在当时运行良好
- 设置身份验证选项/执行失败的位置
- 可以使用以下命令再现此问题:在使用RTSPATT生成的虚拟RTSP服务器上运行
docker run --rm -e RTSP_AUTHENTICATION_METHOD="digest" -p 8554:8554 ullaakut/rtspatt
另外,只是为了明确,我没有禁用libcurl中的rtsp协议,在运行curl --version时它已启用(但是,正如前面所述,使用基本身份验证也可以正常工作):
curl 7.64.1 (x86_64-apple-darwin19.0) libcurl/7.64.1 (SecureTransport) LibreSSL/2.8.3 zlib/1.2.11 nghttp2/1.39.2
Release-Date: 2019-03-27
Protocols: dict file ftp ftps gopher http https imap imaps ldap ldaps pop3 pop3s rtsp smb smbs smtp smtps telnet tftp
Features: AsynchDNS GSS-API HTTP2 HTTPS-proxy IPv6 Kerberos Largefile libz MultiSSL NTLM NTLM_WB SPNEGO SSL UnixSockets
最后一个额外说明,我能够在Linux和MacOS上重现此问题,并且我的项目的许多用户也在各种Linux发行版上遇到了同样的问题。
curl -v -X describe 'rtsp://ubnt:administrator@127.0.0.1:8554/live.sdp'
使用netcat服务器:printf 'RTSP/1.0 401 Unauthorized\r\nCSeq: 1\r\nWWW-Authenticate: Digest realm="GStreamer RTSP Server", nonce="3034e78651e4e61e"\r\nServer: GStreamer RTSP server\r\nDate: Sun, 12 Jan 2020 09:36:53 GMT\r\n\r\n' | nc -l 8554
- hanshenrik