From eb80f92cec5359b61a5849355ec8dcf16c820cef Mon Sep 17 00:00:00 2001 From: Sektor van Skijlen Date: Mon, 16 Oct 2023 11:21:46 +0200 Subject: [PATCH] [core] Fixed: properly handle strings with NULL characters inside (#2804). --- srtcore/core.cpp | 16 +++++++++++++++- srtcore/socketconfig.h | 2 +- 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/srtcore/core.cpp b/srtcore/core.cpp index 9587cc793..c45eef14a 100644 --- a/srtcore/core.cpp +++ b/srtcore/core.cpp @@ -2786,7 +2786,21 @@ bool srt::CUDT::interpretSrtHandshake(const CHandShake& hs, // Un-swap on big endian machines ItoHLA((uint32_t *)target, (uint32_t *)target, blocklen); - m_config.sStreamName.set(target, strlen(target)); + // Determine the length by dropping all but one of terminal NUL characters. + + size_t targetlen = bytelen; + for (size_t pos = bytelen - 1; pos != 0; --pos) + { + if (target[pos]) + { + // Found the first non-NUL character backwards + // So the length is pos+1 + targetlen = pos + 1; + break; + } + } + + m_config.sStreamName.set(target, targetlen); HLOGC(cnlog.Debug, log << CONID() << "CONNECTOR'S REQUESTED SID [" << m_config.sStreamName.c_str() << "] (bytelen=" << bytelen << " blocklen=" << blocklen << ")"); diff --git a/srtcore/socketconfig.h b/srtcore/socketconfig.h index e50b021d5..8a78ea21e 100644 --- a/srtcore/socketconfig.h +++ b/srtcore/socketconfig.h @@ -170,7 +170,7 @@ class StringStorage std::string str() const { - return len == 0 ? std::string() : std::string(stor); + return len == 0 ? std::string() : std::string(stor, len); } const char* c_str() const