Skip to content

Deserialization Attack

Description

Deserialization attacks occur when untrusted data is used to construct objects, potentially leading to remote code execution, denial of service, or other malicious actions. Example: Deserializing a crafted payload that includes malicious code to be executed upon deserialization.

Remediation

To prevent deserialization vulnerabilities, take the following actions:

  • Avoid deserializing untrusted data whenever possible.
  • Use safe deserialization libraries that parovide security features.
  • Implement strict input validation and sanitization to ensure that only trusted data is deserialized.
  • Use whitelisting techniques to restrict the types of objects that can be deserialized.
  • Apply security controls such as application-level sandboxing to limit the impact of a potential deserialization attack.

REST Specific

Spring_boot Use a secure deserialization library like Jackson with a safe module configuration. Avoid using Java native serialization and enforce strict input validation. Implement a whitelist of allowed classes for deserialization and apply security controls to limit the impact of any exploitation attempts.
Django Use Django's built-in JSON deserialization mechanisms and avoid custom deserialization code. Implement strict input validation and whitelisting of acceptable object types. Regularly update Django to benefit from security patches.
Flask Use secure deserialization libraries such as itsdangerous to handle untrusted data. Validate and sanitize inputs before deserialization and avoid using pickle or other unsafe methods. Implement security controls to sandbox deserialization processes.
Nodejs Use libraries like `serialize-javascript` and `safe-eval` to handle deserialization securely. Avoid using `eval()` or `Function()` to process deserialized data. Validate all inputs and use a strict schema to define acceptable data structures.
Ruby_on_rails Use Rails' built-in mechanisms for safe deserialization, such as JSON.parse. Avoid using YAML.load or Marshal.load with untrusted data. Enforce input validation and use a whitelist approach for deserializable classes.
Laravel Use Laravel's native serialization mechanisms to handle data securely. Avoid using PHP's `unserialize()` on untrusted data. Validate and sanitize inputs before processing and enforce strict type checks.
Express_js Use secure libraries for deserialization in Express.js applications. Validate and sanitize all inputs before deserialization and avoid using `eval()` or other unsafe methods. Implement strict schema validation to ensure only trusted data is processed.
Symfony Use Symfony's Serializer component securely by validating and sanitizing inputs. Avoid using `unserialize()` on untrusted data and enforce strict class type whitelisting. Regularly update Symfony components to incorporate security fixes.
Nuxt Use secure libraries for deserialization in Nuxt.js applications. Validate and sanitize all inputs before deserialization and avoid using unsafe methods like `eval()`. Implement strict schema validation to ensure only trusted data is processed.
Fastapi Use Pydantic models in FastAPI to validate and deserialize data securely. Avoid using `eval()` or other unsafe methods for processing deserialized data. Enforce strict schema validation and regularly update dependencies to benefit from security patches.
Asp_net Implement a secure deserialization library and validate all incoming serialized data to ensure it is from a trusted source before deserialization.
Frappe Validate and sanitize all serialized data before deserialization in the Frappe framework to prevent execution of malicious code.
Genzio Implement strict input validation and use a secure deserialization library to prevent deserialization of untrusted data in the Genzio framework engine.
Gin Validate and sanitize all input data before deserialization in the Gin framework to prevent deserialization attacks.
Gorilla Implement input validation and use a secure deserialization library to prevent deserialization of untrusted data in the Gorilla framework.
Hapi Validate and sanitize all input data before deserialization in the Hapi framework to prevent deserialization attacks.
Hono Validate and sanitize all input data before deserialization to prevent deserialization attacks in the Hono framework engine.
Jersey Validate and sanitize all input data before deserialization in the Jersey framework to prevent deserialization attacks.
Koa Validate and sanitize all input data before deserialization in the Koa framework to prevent deserialization attacks.
Ktor Use a secure serialization library and validate all incoming data before deserialization in Ktor applications
Leptos Validate and sanitize all input data before deserialization in the Leptos framework to prevent execution of malicious code.
Macaron Validate and sanitize all input data before deserialization in the Macaron framework to prevent deserialization attacks.
Next_js Validate and sanitize all input data before deserialization in Next.js applications to prevent deserialization attacks.
Phoenix Use safe deserialization libraries and validate or sanitize all input data before deserialization in the Phoenix framework.
Redwoodjs Validate and sanitize all input data before deserialization in RedwoodJS applications to prevent deserialization attacks.
Rocket Validate and sanitize all input data before deserialization in Rocket framework to prevent deserialization attacks.
Sveltekit Validate and sanitize all input data before deserialization in SvelteKit applications to prevent deserialization attacks.

Configuration

Identifier: injection/deserialization_attack

Examples

Ignore this check

checks:
  injection/deserialization_attack:
    skip: true

Score

  • Escape Severity:

Compliance

  • OWASP: API10:2023
  • OWASP LLM: LLM04:2023
  • pci: 6.5.2
  • gdpr: Article-32
  • soc2: CC6
  • psd2: Article-95
  • iso27001: A.14.2
  • nist: SP800-53
  • fedramp: SI-10

Classification

  • CWE: 502

Score

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

References