(PHP 4, PHP 5, PHP 7, PHP 8)
extract — Importiert Variablen eines Arrays in die aktuelle Symboltabelle
Diese Funktion wird verwendet, um Variablen eines Arrays in die aktuelle Symboltabelle zu importieren.
Jeder Schlüssel wird geprüft, ob er einen gültigen Variablennamen ergibt und ob es Kollisionen mit existierenden Variablen in der Symboltabelle gibt.
array
Ein assoziatives Array. Die Funktion behandelt Schlüssel als
Variablennamen und Werte als Variablenwerte. Für jedes Paar
Schlüssel/Wert wird - abhängig von den Parametern
flags
und prefix
- eine
Variable in der aktuellen Symboltabelle eingetragen.
Sie müssen ein assoziatives Array verwenden, da ein numerisch
indiziertes Array zu keinem Ergebnis führt, außer Sie verwenden
EXTR_PREFIX_ALL
oder
EXTR_PREFIX_INVALID
.
flags
Die Art, wie ungültige/numerische Schlüssel und Kollisionen behandelt
werden, wird durch flags
bestimmt. Die folgenden
Werte sind erlaubt:
EXTR_OVERWRITE
EXTR_SKIP
EXTR_PREFIX_SAME
prefix
vorangestellt.
EXTR_PREFIX_ALL
prefix
vorangestellt.
EXTR_PREFIX_INVALID
prefix
vorangestellt.
EXTR_IF_EXISTS
EXTR_PREFIX_IF_EXISTS
EXTR_REFS
array
referenzieren. Sie können dieses Flag
alleine oder auch in Kombination mit einem anderen Flag verwenden,
indem Sie die flags
mit OR verknüpfen.
Ist flags
nicht angegeben, so wird
EXTR_OVERWRITE
angenommen.
prefix
Beachten Sie, dass prefix
nur dann nötig ist,
wenn flags
EXTR_PREFIX_SAME
,
EXTR_PREFIX_ALL
,
EXTR_PREFIX_INVALID
oder
EXTR_PREFIX_IF_EXISTS
ist. Ist das Resultat trotz
Präfix kein gültiger Variablenname, wird es nicht in die Symboltabelle
importiert. Präfixe werden automatisch mit einem Unterstrich vom
Schlüssel des Arrays getrennt.
extract() gibt die Anzahl der erfolgreich in die Symboltabelle importierten Variablen zurück.
Beispiel #1 extract()-Beispiel
Eine mögliche Verwendung für extract() ist, Variablen in die Symboltabelle zu importieren, die in einem von wddx_deserialize() zurückgegebenen assoziativen Array enthalten sind.
<?php
/* Annahme: $var_array ist ein von wddx_deserialize
zurückgegebenes Array */
$groesse = "groß";
$var_array = array("farbe" => "blau",
"groesse" => "mittel",
"form" => "Kugel");
extract($var_array, EXTR_PREFIX_SAME, "wddx");
echo "$farbe, $groesse, $form, $wddx_groesse\n";
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
blau, groß, Kugel, mittel
$groesse wurde nicht überschrieben, da wir
EXTR_PREFIX_SAME
angegeben haben. Das führte dazu,
dass $wddx_groesse erstellt wurde. Mit der Angabe
EXTR_SKIP
wäre $wddx_groesse
nicht erstellt worden. EXTR_OVERWRITE
hätte
$groesse mit dem Wert "mittel" überschrieben, und
EXTR_PREFIX_ALL
hätte die neuen Variablen
$wddx_farbe, $wddx_groesse, und
$wddx_form erstellt.
Verwenden Sie extract() nicht für nicht
vertrauenswürdige Daten wie Benutzereingaben (d. h.
$_GET, $_FILES, ...). Wenn Sie das
tun, stellen Sie sicher, dass Sie einen der nicht überschreibenden
flags
-Werte wie z. B. EXTR_SKIP
verwenden und beachten Sie, dass Sie die Daten in der selben Reihenfolge
extrahieren müssen, die in variables_order in der php.ini angegeben wurde.