Lucene search
K

Linux Distros Unpatched Vulnerability : CVE-2025-66570

🗓️ 08 Dec 2025 00:00:00Reported by TenableType 
nessus
 nessus
🔗 www.tenable.com👁 3 Views

Linux hosts using cpp-httplib prior to 0.27.0 are vulnerable to header spoofing that affects logs and authorization.

Related
Refs
Code
ReporterTitlePublishedViews
Family
Circl
CVE-2025-66570
5 Dec 202521:38
circl
CNNVD
cpp-httplib 安全漏洞
5 Dec 202500:00
cnnvd
CVE
CVE-2025-66570
5 Dec 202518:18
cve
Cvelist
CVE-2025-66570 cpp-httplib Untrusted HTTP Header Handling: Internal Header Shadowing (REMOTE*/LOCAL*)
5 Dec 202518:18
cvelist
Debian CVE
CVE-2025-66570
5 Dec 202518:18
debiancve
EUVD
EUVD-2025-201455
5 Dec 202518:18
euvd
Fedora
[SECURITY] Fedora 42 Update: cpp-httplib-0.30.1-5.fc42
22 Jan 202601:15
fedora
Fedora
[SECURITY] Fedora 43 Update: cpp-httplib-0.30.1-5.fc43
22 Jan 202601:08
fedora
Tenable Nessus
Fedora 42 : cpp-httplib (2026-3b0e5b457d)
22 Jan 202600:00
nessus
Tenable Nessus
Fedora 43 : cpp-httplib (2026-e50e41fcea)
22 Jan 202600:00
nessus
Rows per page
#%NASL_MIN_LEVEL 80900
##
# (C) Tenable, Inc.
##

include('compat.inc');

if (description)
{
  script_id(277659);
  script_version("1.9");
  script_set_attribute(attribute:"plugin_modification_date", value:"2026/05/21");

  script_cve_id("CVE-2025-66570");

  script_name(english:"Linux Distros Unpatched Vulnerability : CVE-2025-66570");

  script_set_attribute(attribute:"synopsis", value:
"The Linux/Unix host has one or more packages installed with a vulnerability that the vendor indicates will not be
patched.");
  script_set_attribute(attribute:"description", value:
"The Linux/Unix host has one or more packages installed that are impacted by a vulnerability without a vendor supplied
patch available.

  - cpp-httplib is a C++11 single-file header-only cross platform HTTP/HTTPS library. Prior to 0.27.0, a
    vulnerability allows attacker-controlled HTTP headers to influence server-visible metadata, logging, and
    authorization decisions. An attacker can inject headers named REMOTE_ADDR, REMOTE_PORT, LOCAL_ADDR,
    LOCAL_PORT that are parsed into the request header multimap via read_headers() in httplib.h
    (headers.emplace), then the server later appends its own internal metadata using the same header names in
    Server::process_request without erasing duplicates. Because Request::get_header_value returns the first
    entry for a header key (id == 0) and the client-supplied headers are parsed before server-inserted
    headers, downstream code that uses these header names may inadvertently use attacker-controlled values.
    Affected files/locations: cpp-httplib/httplib.h (read_headers, Server::process_request,
    Request::get_header_value, get_header_value_u64) and cpp-httplib/docker/main.cc (get_client_ip,
    nginx_access_logger, nginx_error_logger). Attack surface: attacker-controlled HTTP headers in incoming
    requests flow into the Request.headers multimap and into logging code that reads forwarded headers,
    enabling IP spoofing, log poisoning, and authorization bypass via header shadowing. This vulnerability is
    fixed in 0.27.0. (CVE-2025-66570)

Note that Nessus relies on the presence of the package as reported by the vendor.");
  script_set_attribute(attribute:"see_also", value:"https://security-tracker.debian.org/tracker/CVE-2025-66570");
  script_set_attribute(attribute:"see_also", value:"https://ubuntu.com/security/CVE-2025-66570");
  script_set_attribute(attribute:"solution", value:
"There is no known solution at this time.");
  script_set_attribute(attribute:"agent", value:"unix");
  script_set_cvss_base_vector("CVSS2#AV:N/AC:M/Au:N/C:N/I:P/A:N");
  script_set_cvss_temporal_vector("CVSS2#E:POC/RL:U/RC:C");
  script_set_cvss3_base_vector("CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H");
  script_set_cvss3_temporal_vector("CVSS:3.0/E:P/RL:U/RC:C");
  script_set_attribute(attribute:"cvss_score_source", value:"CVE-2025-66570");

  script_set_attribute(attribute:"exploitability_ease", value:"Exploits are available");
  script_set_attribute(attribute:"exploit_available", value:"true");
  script_set_attribute(attribute:"vendor_unpatched", value:"true");

  script_set_attribute(attribute:"vuln_publication_date", value:"2025/12/05");
  script_set_attribute(attribute:"plugin_publication_date", value:"2025/12/08");

  script_set_attribute(attribute:"plugin_type", value:"local");
  script_set_attribute(attribute:"cpe", value:"cpe:/o:canonical:ubuntu_linux:25.04");
  script_set_attribute(attribute:"cpe", value:"cpe:/o:debian:debian_linux:12.0");
  script_set_attribute(attribute:"cpe", value:"cpe:/o:debian:debian_linux:13.0");
  script_set_attribute(attribute:"cpe", value:"p-cpe:/a:canonical:ubuntu_linux:cpp-httplib");
  script_set_attribute(attribute:"cpe", value:"p-cpe:/a:debian:debian_linux:cpp-httplib");
  script_set_attribute(attribute:"generated_plugin", value:"current");
  script_end_attributes();

  script_category(ACT_GATHER_INFO);
  script_family(english:"Misc.");

  script_copyright(english:"This script is Copyright (C) 2025-2026 and is owned by Tenable, Inc. or an Affiliate thereof.");

  script_dependencies("ssh_get_info2.nasl", "set_linux_os_id.nasl");
  script_require_keys("Host/cpu", "Host/local_checks_enabled", "global_settings/vendor_unpatched", "Host/OS/identifier");
  script_require_ports("Host/OS/Debian Linux-12", "Host/OS/Debian Linux-13", "Host/OS/Ubuntu Linux-25.04");

  exit(0);
}

if (!get_kb_item("global_settings/vendor_unpatched")) exit(0, "Unpatched Vulnerabilities Detection not active.");
if (!get_kb_item("Host/local_checks_enabled")) audit(AUDIT_LOCAL_CHECKS_NOT_ENABLED);
if (empty_or_null(get_one_kb_item("Host/Debian/dpkg-l"))) audit(AUDIT_PACKAGE_LIST_MISSING);

include('linux_unpatched.inc');

var distro_constraints_array = {
  "Debian Linux-12": {
    "package_manager": "dpkg-l",
    "constraints": [
      {
        "release": "12",
        "pkgs": [
          {"reference": "libcpp-httplib-dev"},
          {"reference": "libcpp-httplib0.11"}
        ]
      }
    ]
  },
  "Debian Linux-13": {
    "package_manager": "dpkg-l",
    "constraints": [
      {
        "release": "13",
        "pkgs": [
          {"reference": "libcpp-httplib-dev"},
          {"reference": "libcpp-httplib0.18"}
        ]
      }
    ]
  },
  "Ubuntu Linux-25.04": {
    "package_manager": "dpkg-l",
    "constraints": [
      {
        "release": "25.04",
        "pkgs": [
          {"reference": "cpp-httplib"}
        ]
      }
    ]
  }
};

var distro_constraints_values = linux_unpatched::get_distro_constraints(distro_constraints_arr:distro_constraints_array);
if (empty_or_null(distro_constraints_values)) audit(AUDIT_HOST_NOT, 'affected');
var report = linux_unpatched::check_unpatched_constraints(distro_constraints_values:distro_constraints_values);

if (!empty_or_null(report))
{
  security_report_v4(
      port       : 0,
      severity   : SECURITY_WARNING,
      extra      : report
  );
  exit(0);
}
else
{
  audit(AUDIT_HOST_NOT, 'affected');
}

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation

21 May 2026 00:00Current
7.2High risk
Vulners AI Score7.2
CVSS 3.19.8 - 10
EPSS0.00031
SSVC
3