Skip to content

Directory traversal

Description

Directory traversal occurs when a server allows an attacker to read a file or directories outside of the normal web server directory, and local file inclusion gives the attacker the ability to include an arbitrary local file (from the web server) in the web server's response.

Remediation

There are multiple ways to prevent directory traversal attacks:

  • Avoid using parameters entered directly by the user.
  • Set up a file/folder name whitelist system: allow only certain folders and/or types of extensions, thus excluding all others.
  • Compartmentalize your data and implement middlewares. These can take the form of an interface to the (potentially external) file system on which the data users may request is stored. If the attached data storage is dedicated to this purpose only and does not contain sensitive data, the risk is limited, even if a user manages to bypass the limitations that this middleware can put in place.
  • Restrict access of the GraphQL worker to what is strictly necessary. By restricting as much as possible the files and folders to which the GraphQL worker has access, you reduce the range of files potentially exposed by an attack.
  • Take advantage of virtualization. With virtualization, it is possible to have several virtual machines completely isolated from each other. The GraphQL worker can therefore be isolated on its own virtual machine, allowing it access only to the elements absolutely necessary for its proper execution.

REST Specific

Asp_net In ASP.NET, prevent directory traversal attacks by validating user input, using built-in functions to sanitize file paths, employing the Path.Combine() method to safely create file paths, and setting proper permissions. Always restrict file access to a specific whitelist of allowed files and directories, and avoid using user-controllable input to access file system objects directly.
Ruby_on_rails In Ruby on Rails, ensure that user-supplied input is not used directly to access file system objects. Use built-in Rails methods such as 'send_file' or 'send_data' for serving files, and always validate and sanitize input paths. Implement strict input validation to allow only a predetermined set of paths. Avoid passing user-controllable data to methods that access the file system, and consider using the 'brakeman' gem to scan for potential vulnerabilities.
Next_js In Next.js, to prevent directory traversal attacks, ensure that user input is not directly used to access file system paths. Use a whitelist of allowed paths, validate and sanitize input using libraries like `path` to resolve and normalize paths, and avoid exposing sensitive system files. Implement proper error handling to avoid revealing directory structures. Additionally, use built-in Next.js routing and avoid manual path concatenation where possible.
Laravel In Laravel, use the built-in functions such as 'storage_path()' and 'public_path()' to safely reference files within the application's directories. Always validate and sanitize user input to ensure it does not contain directory traversal sequences like '../'. Implement access controls to restrict file access to authorized users only.
Express_js In Express.js, to prevent directory traversal attacks, ensure that user input is not directly used to access file system paths. Validate and sanitize input by using modules like 'path' to resolve and normalize paths, and 'express-fileupload' or similar middleware to handle file uploads securely. Always restrict file access to intended directories and set proper permissions. Additionally, employ a robust authentication and authorization strategy to limit access to sensitive files and directories.
Django In Django, ensure that any file access operations are restricted to the intended directories by using the built-in storage system classes such as 'FileSystemStorage' or 'DefaultStorage', and avoid directly handling file system paths from user input. Always validate and sanitize input to prevent directory traversal, and use 'os.path.join()' with 'settings.MEDIA_ROOT' or 'settings.STATIC_ROOT' for constructing file paths. Additionally, employ Django's 'get_valid_filename()' function to clean the user-supplied filenames.
Symfony In Symfony, to prevent directory traversal attacks, always use the 'file_locator' service to safely locate files, and validate and sanitize all user inputs. Avoid directly passing user-controlled paths to filesystem functions. Use 'realpath()' to resolve paths and check they are within expected directories.
Spring_boot In Spring Boot, to prevent directory traversal attacks, validate and sanitize all user inputs to ensure they do not contain file system navigation characters. Use built-in functions to construct file paths and avoid directly concatenating user input to file paths. Implement proper access control checks before serving files to users.
Flask In Flask, ensure that file access operations use a secure function that restricts paths to the intended directories. Validate and sanitize all user input to prevent directory traversal. Avoid using user input directly in file system operations and employ the `os.path.join` function with `flask.safe_join` to construct file paths. Additionally, set proper permissions on the server to limit which files can be accessed by the web application.
Nuxt In Nuxt.js, to prevent directory traversal attacks, ensure that user input is not directly used to access file system paths. Use a whitelist of allowed paths, validate and sanitize input using libraries like `validator`, and avoid using user input for file system operations without strict checks. Additionally, employ the built-in `fs` module with caution and always resolve paths with `path.resolve` to avoid unintentional exposure of sensitive files.
Fastapi In FastAPI, to prevent directory traversal attacks, ensure that user-supplied file paths are strictly validated against a whitelist of allowed paths. Use secure functions for file access, avoid direct filesystem access with user input, and employ the `pathlib` library to safely construct file paths. Additionally, set proper permissions on the server to restrict access to sensitive directories.
Frappe Validate and sanitize all user inputs to prevent directory traversal and local file inclusion vulnerabilities in the Frappe framework.
Genzio Implement strict input validation and sanitize user inputs to prevent directory traversal attacks in the Genzio framework engine.
Gin Validate and sanitize all user inputs to prevent directory traversal attacks in the Gin framework by using secure functions to handle file paths and avoid direct manipulation of file system paths.
Gorilla Validate and sanitize all user inputs to prevent directory traversal attacks by ensuring that file paths do not contain sequences like '../' that could lead to accessing unauthorized directories.
Hapi Validate and sanitize user input to prevent directory traversal in the Hapi framework by using path utilities like 'path.join' and 'path.normalize' to ensure file paths remain within the intended directory.
Hono Validate and sanitize all user inputs to prevent directory traversal attacks, and ensure that file paths are resolved to a safe base directory within the Hono framework engine.
Jersey Validate and sanitize all user inputs to prevent directory traversal attacks in the Jersey framework.
Koa Validate and sanitize user input to prevent directory traversal attacks, and use libraries like 'path' in Node.js to resolve and normalize file paths securely in the Koa framework.
Ktor Validate and sanitize all user inputs to prevent directory traversal attacks in the Ktor framework by ensuring that file paths are canonicalized and restricted to a specific directory.
Leptos Validate and sanitize all user inputs to prevent directory traversal and local file inclusion vulnerabilities in the Leptos framework.
Macaron Validate and sanitize all user inputs to prevent directory traversal attacks in the Macaron framework.
Phoenix Validate and sanitize user inputs to prevent directory traversal and local file inclusion vulnerabilities in the Phoenix Framework.
Redwoodjs Validate and sanitize user inputs to prevent directory traversal and ensure that file paths are restricted to a safe directory within the RedwoodJS application.
Rocket Validate and sanitize all user inputs to prevent directory traversal and local file inclusion vulnerabilities in the Rocket framework.
Sveltekit Validate and sanitize user inputs to prevent directory traversal in SvelteKit applications, and use built-in security features to restrict file access to only necessary directories.

Configuration

Identifier: injection/directory_traversal

Options

  • skip_objects : List of object that are to be skipped by the security test.

Examples

Ignore this check

checks:
  injection/directory_traversal:
    skip: true

Score

  • Escape Severity:

Compliance

  • OWASP: API10:2023
  • OWASP LLM: LLM06:2023
  • pci: 6.5.1
  • gdpr: Article-32
  • soc2: CC6
  • psd2: Article-95
  • iso27001: A.14.2
  • nist: SP800-53
  • fedramp: AC-6

Classification

  • CWE: 551

Score

  • CVSS_VECTOR: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N/E:H/RL:O/RC:C
  • CVSS_SCORE: 7.2

References