2.2.4 Fingerprinting Custom Applications

Fingerprinting Custom Applications

When dealing with custom applications, particularly those tailored for a specific organization, a thorough approach is required to understand their intricacies. Below is a detailed breakdown of the fingerprinting process, with specific examples related to your message.

Initial Overview

  • Understand the Scope:

    • Questions to Address:

      • What is the primary purpose of the application?

      • Does it facilitate user registration?

      • Is there an administration panel?

      • What types of user input are accepted?

      • Does it allow file uploads?

      • Does it utilize JavaScript, AJAX, or Flash?

    • Example:

      • Suppose you're auditing a custom application for a financial institution. Understanding whether it enables online banking, user registrations, and financial transactions is crucial.

  • Visit the Website:

    • Questions to Answer:

      • What is the application's core functionality?

      • Does it involve online sales, corporate presence, or blogging?

      • Are there specific areas that require user authentication?

    • Example:

      • While navigating the website, you may discover that the application is primarily focused on corporate financial management and includes a secure login area for clients.

  • Consider Common Software:

    • Example:

      • Even in a custom application, you might find integrated functionalities such as forums or blogs. Recognizing these can be essential, as they may introduce vulnerabilities commonly associated with off-the-shelf software.

Burp Target Crawler

  • Proxy Setup:

    • Tool:

      • Utilize Burp Proxy for browsing, enabling the configuration of a scope through regular expressions.

    • Example:

      • Configure Burp Proxy to intercept requests related to user authentication or financial transactions within the application.

  • Crawling with Burp:

    • Tool:

      • Enable the Burp crawler (Spider tab) to automatically generate and record requests and response headers.

    • Example:

      • The crawler will traverse through different sections of the financial application, capturing relevant information about the structure and behavior.

Creating a Functional Graph

  • Study the Target:

    • Questions to Answer:

      • What is the primary purpose of each section?

      • Are there specific functionalities tied to user authentication?

      • What are the critical areas, such as eCommerce or client dashboards?

    • Example:

      • Identify that the eCommerce section is a core element, and there are login-protected areas containing sensitive financial data.

  • Study the Blocks:

    • Example:

      • Recognize that certain blocks may use third-party components, like a financial analytics tool or a secure payment gateway. Note any login-protected areas with a rhombus symbol.

  • Functional Graph:

    • Example:

      • Visualize the eCommerce block as a green hexagon, indicating its significance. The graph helps illustrate the application's structure and critical components.

Mapping the Attack Surface

  • Client-Side Validation:

    • Identification:

      • Locate client-side validation points by inspecting JavaScript functions triggered upon form submission.

    • Example:

      • Use tools like Firebug to identify JavaScript functions that validate user inputs in financial transaction forms.

  • Database Interaction:

    • Detection:

      • Identify changes in page appearance indicating active database interaction, as this may hint at SQL injection vulnerabilities.

    • Example:

      • Notice that certain pages dynamically update based on user queries, potentially indicating database interactions for financial data retrieval.

  • File Uploading and Downloading:

    • Example:

      • Identify pages that allow dynamic downloads or file uploads. These areas might pose risks related to Remote or Local File Inclusion vulnerabilities.

  • Display of User Supplied Data:

    • Example:

      • Locate sections displaying user-supplied data, which could be vulnerable to Cross-Site Scripting (XSS) attacks.

  • Redirections:

    • Example:

      • Investigate server-side directives and meta refresh tags. Improper handling could lead to HTTP response splitting and other attacks.

  • Access Controls and Login Protected Pages:

    • Example:

      • Identify login pages and areas protected by authentication. Test the security of these authentication routines.

  • Error Messages:

    • Example:

      • Collect error messages encountered during browsing. While intentional error generation may come later, noting spontaneous errors is crucial.

Charting

  • Organize Information:

    • Example:

      • Use a table-based chart to categorize information for each block, including client-side validation, redirections, database interaction, errors, display of user data, and login details.