• CWE-143: Improper Neutralization of Record Delimiters

Das Produkt empfängt Eingaben von einer vorgelagerten Komponente, neutralisiert diese jedoch nicht oder neutralisiert sie fehlerhaft, sodass spezielle Elemente, die als Record Delimiter interpretiert werden könnten, an eine nachgelagerte Komponente weitergeleitet werden.

CWE-143: Improper Neutralization of Record Delimiters

CWE ID: 143
Name: Improper Neutralization of Record Delimiters

Beschreibung

Das Produkt empfängt Eingaben von einer vorgelagerten Komponente, neutralisiert diese jedoch nicht oder neutralisiert sie fehlerhaft, sodass spezielle Elemente, die als Record Delimiter interpretiert werden könnten, an eine nachgelagerte Komponente weitergeleitet werden.

Erweiterte Beschreibung

Während des Parsing kann ein injizierter, fehlender oder fehlerhafter Delimiter dazu führen, dass der Prozess unerwartete Aktionen ausführt.

Risikominderungsmaßnahmen

Maßnahme (Unknown)

Effektivität: Unknown
Beschreibung: Entwickler sollten davon ausgehen, dass Record Delimiter in den Input Vektoren ihres Produkts injiziert, entfernt oder manipuliert werden. Eine geeignete Kombination aus Denylists und Allowlists sollte verwendet werden, um sicherzustellen, dass nur valide, erwartete und angemessene Eingaben vom System verarbeitet werden.

Maßnahme (Implementation)

Effektivität: Unknown
Beschreibung: Obwohl die Verwendung von dynamisch generierten Query Strings, Code oder Commands, die Kontrollelemente und Daten vermischen, riskant ist, kann dies manchmal unvermeidlich sein. Argumente sollten korrekt in Anführungszeichen gesetzt und alle speziellen Zeichen innerhalb dieser Argumente escaped werden. Der konservativste Ansatz ist, alle Zeichen zu escapen oder zu filtern, die nicht durch eine äußerst strikte Allowlist bestehen (z. B. alles, was nicht alphanumerisch oder Leerzeichen ist). Wenn bestimmte spezielle Zeichen dennoch benötigt werden, wie z. B. Leerzeichen, sollten jedes Argument nach dem Escaping/Filtering-Schritt in Anführungszeichen gesetzt werden. Achten Sie auf Argument Injection (CWE-88).

Maßnahme (Implementation)

Effektivität: Unknown
Beschreibung: Eingaben sollten vor der Validierung in die aktuelle interne Repräsentation der Anwendung dekodiert und kanonisiert werden (CWE-180). Stellen Sie sicher, dass die Anwendung dieselbe Eingabe nicht zweimal dekodiert (CWE-174). Solche Fehler könnten dazu verwendet werden, Allowlist-Validierungsschemata zu umgehen, indem gefährliche Eingaben nach ihrer Prüfung eingeführt werden.