Lucene search
K

c99shell Backdoor Detection

🗓️ 14 May 2010 00:00:00Reported by TenableType 
nessus
 nessus
🔗 www.tenable.com👁 255 Views

The remote web server contains a PHP backdoor script. At least one instance of c99shell (or a derivative, such as c100 or Locus7Shell) is hosted on the remote web server. This is a PHP script that acts as a backdoor and provides a convenient set of tools for attacking the affected host

Refs
Code
#%NASL_MIN_LEVEL 70300
#
# (C) Tenable Network Security, Inc.
#

include('deprecated_nasl_level.inc');
include('compat.inc');

if (description)
{
  script_id(46349);
  script_version("1.9");
  script_set_attribute(attribute:"plugin_modification_date", value:"2022/04/11");

  script_name(english:"c99shell Backdoor Detection");

  script_set_attribute(attribute:"synopsis", value:
"The remote web server contains a PHP backdoor script.");
  script_set_attribute(attribute:"description", value:
"At least one instance of c99shell (or a derivative, such as c100 or
Locus7Shell) is hosted on the remote web server.  This is a PHP script
that acts as a backdoor and provides a convenient set of tools for
attacking the affected host.");
  script_set_attribute(attribute:"see_also", value:"http://vil.nai.com/vil/content/v_136948.htm");
  # https://www.sophos.com/en-us/threat-center/threat-analyses/viruses-and-spyware/PHP~C99Shell-A.aspx
  script_set_attribute(attribute:"see_also", value:"http://www.nessus.org/u?e4884d31");
  script_set_attribute(attribute:"solution", value:
"Remove any instances of the c99shell script and conduct a forensic examination
to determine how it was installed as well as whether other unauthorized
changes were made.");
  script_set_cvss_base_vector("CVSS2#AV:N/AC:L/Au:N/C:P/I:P/A:P");

  script_set_attribute(attribute:"plugin_publication_date", value:"2010/05/14");

  script_set_attribute(attribute:"plugin_type", value:"remote");
  script_set_attribute(attribute:"thorough_tests", value:"true");
  script_end_attributes();

  script_category(ACT_GATHER_INFO);
  script_family(english:"CGI abuses");

  script_copyright(english:"This script is Copyright (C) 2010-2022 Tenable Network Security, Inc.");

  script_dependencies("http_version.nasl");
  script_require_keys("www/PHP");
  script_exclude_keys("Settings/disable_cgi_scanning");
  script_require_ports("Services/www", 80);

  exit(0);
}


include("global_settings.inc");
include("misc_func.inc");
include("http.inc");


port = get_http_port(default:80, php:TRUE);


# Loop through files.
#
# nb: By default, we'll look for it as 'c99.php', 'c99shell.php', and
#     'c100.php' and, if the "Perform thorough tests" setting is enabled, some other
#     common variants. Still, the script can be named anything and
#     won't necessarily be found by webmirror.nasl so a remote check
#     is not likely to be 100% effective.
files = make_list(
  'c99.php',
  'c99shell.php',
  'c100.php'
);
if (thorough_tests)
{
  files = make_list(
    files,
    'index.php',
    'ch99.php'
  );
}

dirs = get_kb_list("www/"+port+"/content/directories");
if (isnull(dirs)) dirs = cgi_dirs();

info = "";
foreach dir (list_uniq("", dirs))
{
  foreach file (files)
  {
    url = dir + '/' + file;
    res = http_send_recv3(port:port, method:"GET", item:url, exit_on_fail:TRUE);
    if (
      res[2] &&
      (
        ('<b>C99Shell v.' >< res[2] || '<b>--[c99shell v.' >< res[2]) &&
        egrep(pattern:'<a href="\\?act=cmd[^"]+"><b>Command execute', string:res[2])
      ) ||
      (
        ('Locus7Shell</title>' || '<b>--[ x2300 Locus7Shell v.' >< res[2]) &&
        egrep(pattern:'<form action="\\?act=cmd"[^>]+><input type=hidden name=act value="cmd">', string:res[2])
      )
    )
    {
      info += '  - ' + build_url(port:port, qs:file) + '\n';

      if (!thorough_tests) break;
    }
  }
  if (info && !thorough_tests) break;
}


# Report findings.
if (info)
{
  if (report_verbosity > 0)
  {
    if (max_index(split(info)) > 1) s = 's';
    else s = '';

    report = '\n' +
      'Nessus discovered the following instance' + s + ' of c99shell :\n' +
      '\n' +
      info;
    security_hole(port:port, extra:report);
  }
  else security_hole(port);

  exit(0);
}
else exit(0, "c99shell was not found on the web server listening on port "+port+".");

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

11 Apr 2022 00:00Current
5.6Medium risk
Vulners AI Score5.6
255