All Projects → erwanlr → Fingerprinter

erwanlr / Fingerprinter

CMS/LMS/Library etc Versions Fingerprinter

Programming Languages

ruby
36898 projects - #4 most used programming language

Projects that are alternatives of or similar to Fingerprinter

Satansword
红队综合渗透框架
Stars: ✭ 482 (+112.33%)
Mutual labels:  security-tools, fingerprinting
Notadd
A microservice development architecture based on nest.js. —— 基于 Nest.js 的微服务开发架构。
Stars: ✭ 2,556 (+1025.99%)
Mutual labels:  cms
Jweb Cms
A developer friendly Java CMS based on JAX-RS, Guice style DI, Bean Validation, JPA and React.
Stars: ✭ 216 (-4.85%)
Mutual labels:  cms
Enoki
ultralight tools for creating p2p sites
Stars: ✭ 222 (-2.2%)
Mutual labels:  cms
Icms2
Official Repository for InstantCMS 2.x
Stars: ✭ 215 (-5.29%)
Mutual labels:  cms
Honggfuzz Rs
Fuzz your Rust code with Google-developed Honggfuzz !
Stars: ✭ 222 (-2.2%)
Mutual labels:  security-tools
Sanity
The Sanity Studio – Collaborate in real-time on structured content
Stars: ✭ 3,007 (+1224.67%)
Mutual labels:  cms
Progpilot
A static analysis tool for security
Stars: ✭ 226 (-0.44%)
Mutual labels:  security-tools
H1domains
HackerOne "in scope" domains
Stars: ✭ 223 (-1.76%)
Mutual labels:  security-tools
Zkeacms
ZKEACMS build with .Net 5 (.Net CMS)可视化设计在线编辑内容管理系统
Stars: ✭ 2,593 (+1042.29%)
Mutual labels:  cms
Tensei
🚀 Content management and distribution with a touch of elegance.
Stars: ✭ 217 (-4.41%)
Mutual labels:  cms
Jekyll Admin
A Jekyll plugin that provides users with a traditional CMS-style graphical interface to author content and administer Jekyll sites.
Stars: ✭ 2,531 (+1014.98%)
Mutual labels:  cms
Asn1crypto
Python ASN.1 library with a focus on performance and a pythonic API
Stars: ✭ 220 (-3.08%)
Mutual labels:  cms
Werdlists
⌨️ Wordlists, Dictionaries and Other Data Sets for Writing Software Security Test Cases
Stars: ✭ 216 (-4.85%)
Mutual labels:  security-tools
Canner
⚡️[NOT MAINTAINED] Content Management Framework creates custom CMS fast and easy. Support data sources such as Firebase/Firestore, GraphQL and Restful APIs.
Stars: ✭ 2,472 (+988.99%)
Mutual labels:  cms
Awesome Java Security
Awesome Java Security Resources 🕶☕🔐
Stars: ✭ 216 (-4.85%)
Mutual labels:  security-tools
Aaia
AWS Identity and Access Management Visualizer and Anomaly Finder
Stars: ✭ 218 (-3.96%)
Mutual labels:  security-tools
Deephack
PoC code from DEF CON 25 presentation
Stars: ✭ 222 (-2.2%)
Mutual labels:  security-tools
Victoire
Fullstack Symfony CMS: The perfect mix between a framework and a CMS
Stars: ✭ 227 (+0%)
Mutual labels:  cms
Zbang
zBang is a risk assessment tool that detects potential privileged account threats
Stars: ✭ 224 (-1.32%)
Mutual labels:  security-tools

Rawsec's CyberSecurity Inventory

Fingerprinter

This script goal is to try to find the version of the remote application/third party script etc by using a fingerprinting approach.

Installation

Inside the cloned repo directory:

$ gem install bundler
$ bundle install

Currently Supported Apps (along with some location/s of versions being disclosed)

Unsupported Apps (along with the reason, useful links & location/s of versions being disclosed)

  • AngularJS - Fingerprints not needed for that (see below) [Payloads | Vulns]
    • Version disclosed from:
      • filename or filepath
      • In the comments at the top of the file
      • By submitting angular.version in the Web Dev console of the Web browser on a page where the lib is loaded
  • Boostrap - Fingerprints not needed for that (see below) [CVEs | Vulns]
    • Version disclosed from:
      • Filename of filepath
      • In the Comments at the top of the file
  • ExpressionEngine - Need to be registered to download the latest free core version. No page to DL them all. [CVEs | Exploit DB]
    • Version disclosed from the footer and rss link (generator tag)
  • jQuery - Fingerprints not needed for that (see below) [CVEs | Vulns]
    • Version disclosed from:
      • Filename of filepath
      • In the Comments at the top of the file
      • By submitting $().jquery or jQuery().jquery in the Web Dev console of the Web browser on a page where the lib is loaded
  • jQuery UI - Fingerprints not needed for that (see below) [CVEs | Vulns]
    • Version disclosed from:
      • Filename of filepath
      • In the Comments at the top of the file
      • By submitting $.fn.jquery or jQuery.fn.jquery in the Web Dev console of the Web browser on a page where the lib is loaded
  • Kentico CMS - Need to provide personal details / register to DL the latest free version [Exploit DB | Hotfixes]
    • Main version disclosed from
      • /CMSHelp/ (in title tag)
      • /CMSPages/GetDocLink.ashx (in the Location header)
  • MustacheJS - Fingerprints not needed for that (see below) [Vulns]
    • Version disclosed from:
      • Filename of filepath
      • Look for mustache.version in the file
  • MomentJS - Fingerprints not needed for that (see below) [Vulns]
    • Version disclosed from:
      • Filename of filepath
      • Look for var v,Aj= in the file
      • By submitting moment.version in the Web Dev console of the Web browser on a page where the lib is loaded
  • PrettyPhoto - Fingerprints no needed for that (see below) [CVEs]
    • Version disclosed from the comments at the top of the file
  • SharePoint - Not free / couldn't find a free or CE edition [Exploit DB | Version numbers (not up-to-date)]
    • Version disclosed from /_vti_pvt/service.cnf
  • Sitecore CMS - Need to be registered, not sure if all versions would then be available to DL [CVEs | Exploit DB | Security Advisories | Latest Version Numbers | Version numbers & revisions]
    • Version disclosed from
      • /sitecore/login
      • /sitecore/shell/sitecore.version.xml
  • ThinkPHP - Framework [CVEs | Versions Released | 3.2.3 Potential Remote Shell]
    • Version disclosed from some 404s in the footer, like /login
  • vBulletin - Not free [Sucuri | Security Announcements | Exploit DB]
    • Version disclosed from:
      • generator meta tag and footer copyright in all pages
      • /clientscript/vbulletin_global.js
      • /clientscript/vbulletin_menu.js
      • /clientscript/vbulletin-core.js

Basic Usage Examples

Using all the Fingerprints
./fingerprinter.rb --app-name wordpress --fingerprint http://target.com/blog/
Using unique Fingerprints

With this mode, only the unique Fingerprints (across all the application's versions files) will be tested. This mode is faster than the previous one, and more reliable. However it is possible that an application's version does not have any unique fingerprints (like Apache Icons, which only has 2 unique fingerprints for the version 2.4.4, and none for the others)

./fingerprinter.rb --app-name wordpress --unique-fingerprint http://target.com/blog/
Using passive fingerprinting mode

In this mode, the homepage of the target is scanned for included ressources such as JavaScript files, Images and so on which are then checked against the DB.

./fingerprinter.rb --app-name wordpress --passive-fingerprint http://target.com/blog/

Options

-p, --proxy PROXY                   Proxy to use during the fingerprinting
    --timeout SECONDS               The number of seconds for the request to be performed, default 20s
    --connect-timeout SECONDS       The number of seconds for the connection to be established before timeout, default 5s
    --cookies-file, --cf FILE-PATH  The cookies file to use during the fingerprinting
    --cookies-string, --cs COOKIE/S The cookies string to use in requests
    --user-agent, --ua UA           User-Agent to use in all fingerprinting requests
-d, --db PATH-TO-DB                 Path to the db of the app-name (default is db/<app-name>.json)
-u, --update                        Update the db of the app-name
-m, --manual DIRECTORY-PATH         To be used along with the --update and --version options. Process the (local) DIRECTORY-PATH and compute the file fingerprints
    --version                       Used with --manual to set the version of the processed fingerprints
    --update-all,                   Update all the apps, except the wordpress plugins and themes
-v, --verbose                       Verbose Mode

Example: Add the file fingerprints from /tmp/test into the Liferay DB for the v6.2

./fingerprinter -a liferay --update --manual /tmp/test --version 6.2

Search the Application Database

Along with the --app-name option (or -a), the database can be searched:

--list-version, --lv                       List all the known versions in the DB for the given app
--list-files, --lf VERSION                 List all files related to the version for the given app
--list-unique-fingerprints, --luf VERSION  List the unique hashes related to the files for the supplied version of the app
--search-hash, --sh HASH                   Search the hash and output the app-name versions & file
--search-file, --sf FILE                   Search the file (ie --sf read will return aread.txt, readme.html etc) and output the app-name versions & hashes

Example: List all the unique Fingerprints for WordPress 3.8.1

./fingerprinter.rb -a wordpress --luf 3.8.1

--help

Usage: ./fingerprinter.rb [options]
    -p, --proxy PROXY                                  Proxy to use during the fingerprinting
        --timeout SECONDS                              The number of seconds for the request to be performed, default 20s
        --cookies-file, --cf FILE-PATH                 The cookies file to use during the fingerprinting
        --cookies-string, --cs COOKIE/S                The cookies string to use in requests
        --user-agent, --ua UA                          User-Agent to use in all fingerprinting requests
    -a, --app-name APPLICATION                         The application to fingerprint. Currently supported: apache-icons, chamilo-lms, ckeditor, cms-made-simple, concrete5, django-cms, dnn-cms drupal, fckeditor, joomla, liferay, magento-ce, mantisbt, mediaelement, moodle, phpmyadmin, prestashop, punbb, tinymce, umbraco, wordpress
    -d, --db PATH-TO-DB                                Path to the db of the app-name
    -u, --update                                       Update the db of the app-name
        --manual DIRECTORY-PATH                        To be used along with the --update and --version options. Process the (local) DIRECTORY-PATH and compute the file fingerprints
        --version VERSION                              Used with --manual to set the version of the processed fingerprints
        --update-all,                                  Update all the apps
        --list-versions, --lv                          List all the known versions in the DB for the given app
        --list-files, --lf VERSION                     List all files related to the version for the given app
        --list-unique-fingerprints, --luf VERSION      List the unique hashes related to the files for the supplied version of the app
        --search-hash, --sh HASH                       Search the hash and output the app-name versions & file
        --search-file, --sf FILE                       Search the file using a LIKE method (so % can be used, e.g: readme%) and output the app-name versions & hashes
        --fingerprint URL                              Fingerprint the app-name at the given URL using all fingerprints
        --unique-fingerprint, --uf URL                 Fingerprint the app-name at the given URL using unique fingerprints
        --passive-fingerprint, --pf URL                Passively fingerprint the URL
        --db-verbose, --dbv                            Database Verbose Mode
    -v, --verbose                                      Verbose Mode
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].