#%NASL_MIN_LEVEL 70300
#
# (C) Tenable Network Security, Inc.
#
include('deprecated_nasl_level.inc');
include("compat.inc");
if(description)
{
script_id(15588);
script_version("1.23");
script_set_attribute(attribute:"plugin_modification_date", value:"2022/04/11");
script_name(english:"Web Server SSL Port HTTP Traffic Detection");
script_set_attribute(attribute:"synopsis", value:
"An SSL detection issue might impede the Nessus Scan.");
script_set_attribute(attribute:"description", value:
"Nessus has discovered that it is talking in plain HTTP on an SSL port.
Nessus has corrected this issue by enabling HTTPS for this port only.
However, if other SSL ports are used on the remote host, they might be
skipped.");
script_set_attribute(attribute:"solution", value:
"Enable SSL tests in the 'Services' preference setting, or increase the
timeouts if this option is already set and the plugin missed this
port.");
script_set_attribute(attribute:"risk_factor", value:"None");
script_set_attribute(attribute:"plugin_publication_date", value:"2004/11/01");
script_set_attribute(attribute:"plugin_type", value:"remote");
script_set_attribute(attribute:"cpe", value:"cpe:/a:apache:http_server");
script_set_attribute(attribute:"thorough_tests", value:"true");
script_end_attributes();
script_category(ACT_GATHER_INFO);
script_family(english:"Web Servers");
script_copyright(english:"This script is Copyright (C) 2004-2022 Tenable Network Security, Inc.");
script_dependencies("find_service1.nasl");
exit(0);
}
#
include("global_settings.inc");
include("misc_func.inc");
banners = get_kb_list("FindService/tcp/*/get_http");
if ( isnull(banners) ) exit(0);
foreach p (keys(banners))
{
# If there are several values, get_kb_item will fork and that's bad.
# However, this only happens when the KB is saved?
b = decode_kb_blob(name: p,value: banners[p]);
port = ereg_replace(string: p, pattern: ".*/([0-9]+)/.*", replace: "\1");
port = int(port);
if (port)
if (# Apache
b =~ "<!DOCTYPE HTML .*You're speaking plain HTTP to an SSL-enabled server" ||
# Webmin
"Bad Request" >< b && "<pre>This web server is running in SSL mode" >< b)
{
security_note(port);
if (COMMAND_LINE) display("\n **** SSL server detected on ", get_host_ip(), ":", port, " ****\n\n");
if (service_is_unknown(port: port))
register_service(port: port, proto: "www");
replace_kb_item(name:"PlainTextOnSSL/"+port, value:1);
for (t = ENCAPS_SSLv2; t <= ENCAPS_TLSv1; t ++)
{
s = open_sock_tcp(port, transport: t);
if (s)
{
send(socket: s, data: 'GET / HTTP/1.0\r\n\r\n');
b = recv(socket: s, length: 4096);
close(s);
set_kb_item(name: "Transport/SSL", value: port);
k = "Transports/TCP/"+port;
replace_kb_item(name: k, value: t);
if (b)
{
set_kb_banner(port: port, type: "get_http", banner: b);
replace_kb_item(name: "www/banner/"+port, value: b);
}
break;
}
}
}
}
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