CWE
Home > CWE List > CWE- Individual Dictionary Definition (1.1)  
Search by ID:

CWE-621: Variable Extraction Error

Individual Definition in a New Window
Variable Extraction Error
Status: Incomplete
Weakness ID: 621 (Weakness Base)
Description
Summary

The product uses external input to determine the names of variables into which information is extracted, without verifying that the names of the specified variables are valid. This could cause the program to overwrite unintended variables.

Extended Description

For example, in PHP, calling extract() or import_request_variables() without the proper arguments could allow arbitrary global variables to be overwritten, including superglobals. Similar functionality might be possible in other interpreted languages, including custom languages.

Alternate Terms
Variable overwrite
Weakness Ordinalities
Primary (where the weakness exists independent of other weaknesses)
Potential Mitigations

Use whitelists of variable names that can be extracted.

Consider refactoring your code to avoid extraction routines altogether.

In PHP, call extract() with options such as EXTR_SKIP and EXTR_PREFIX_ALL; call import_request_variables() with a prefix argument. Note that these capabilities are not present in all PHP versions.

Observed Examples
ReferenceDescription
import_request_variables() buried in include files makes post-disclosure analysis confusing
extract() enables static code injection
extract used for register_globals compatibility layer, enables path traversal
extract issue enables file inclusion
extract() buried in include files makes post-disclosure analysis confusing; original report had seemed incorrect.
Other Notes

In general, variable extraction can make control and data flow analysis difficult to perform. For PHP, extraction can be used to provide functionality similar to register_globals, which is frequently disabled in production systems. Many PHP versions will overwrite superglobals in extract/import_request_variables calls.

Research Gaps

Probably under-reported for PHP. Under-studied for other interpreted languages.

Relationships
NatureTypeIDNameView(s) this relationship pertains toView(s)
ChildOfWeakness ClassWeakness ClassWeakness Class94Code Injection
Research Concepts (primary)1000
ChildOfWeakness ClassWeakness ClassWeakness Class20Insufficient Input Validation
Development Concepts (primary)699
PeerOfWeakness BaseWeakness BaseWeakness Base99Insufficient Control of Resource Identifiers (aka 'Resource Injection')
Research Concepts1000
PeerOfWeakness BaseWeakness BaseWeakness Base471Modification of Assumed-Immutable Data (MAID)
Research Concepts1000
PeerOfWeakness BaseWeakness BaseWeakness Base627Dynamic Variable Evaluation
Research Concepts1000
Applicable Platforms
Languages
PHP
Time of Introduction
* Implementation
Content History
Modifications
Eric Dalci. Cigital. 2008-07-01. (External)
updated Time_of_Introduction
CWE Content Team. MITRE. 2008-09-08. (Internal)
updated Description, Relationships, Observed_Example, Other_Notes, Weakness_Ordinalities
CWE Content Team. MITRE. 2008-10-14. (Internal)
updated Description
Page Last Updated: November 24, 2008