Du bist hier: Tips » Scripte » PHP
PHP
Referenzliste

unpack

Sonstige-Funktionen

    Befehl:
array unpack ( string $format , string $data )


    Parameter-Liste:
NameBeschreibung
formatDie Format-Codes werden unter pack() näher erläutert.
dataDie gepackten Daten.

    Rückgabewerte:
Gibt ein assoziatives Array zurück, dass die entpackten Elemente als Binärzeichenkette enthält.

    Beschreibung:
Überträgt die Daten eines Binär-Strings in ein Array unter Berücksichtigung des format-Parameters.

Die entpackten Daten werden in einem assoziativen Array abgebildet. Hierzu müssen die verschiedenen Format-Codes benannt und mit "/" getrennt werden. Wenn ein sich wiederholendes Argument existiert, werden die Array-Schlüssel durchnummeriert, indem ihnen eine Zahl angehängt wird.


    Aktiv in Version:
(PHP 4, PHP 5, PHP 7)

    Achtung:
Achtung:

Beachten Sie, dass PHP Integer-Werte intern mit Vorzeichen speichert. Wenn Sie einen grossen vorzeichenlosen Longwert entpacken und er von der selben Grösse ist, die PHP für dessen Speicherung verwendet, wird das Ergebnis ein negativer Wert sein (auch wenn Sie dieses als vorzeichenlos zu entpacken angegeben haben).


    Siehe auch:
•  pack()
Packt Daten in eine Binär-Zeichenkette
 

unpack() - Beispiel:


Eingabe:
<?php
$binarydata = "\x04\x00\xa0\x00";
$array = unpack("cchars/nint", $binarydata);
?>


Beschreibung:
Das Ergebnis Array enth�lt die Eintr�ge "chars" mit dem wert 4 und "int" mit 160.

Beschreibung:
Version Beschreibung
5.5.0

Änderungen wurden durchgeführt, um diese Funktion in Übereinstimmung mit Perl zu bringen:

Der "a" Code erhält nun abschliessende NULL Bytes.

Der "A" Code entfernt nun alle abschliessenden ASCII Whitespaces (Leerzeichen, Tabs, Zeilenvorschübe, Wagenrückläufe und NULL Bytes).

Der "Z" Code wurde für mit NULL aufgefüllte Zeichenketten hinzugefügt, und entfernt abschliessende NULL Bytes.

unpack() - Beispiel 2:


Eingabe:
<?php
$binarydata = "\x04\x00\xa0\x00";
$array = unpack("c2chars/nint", $binarydata);
?>


Ausgabe:
3b642d8fb347b
3b642d8fb36015.66211530
Selfphp3b642d8fb37277.76257455
d9b3fe674303124257b0af086fac4325
c831d3184dd81024889ad923abf573f2

Beschreibung:
unpack() - Beispiel 3: unpack() - Beispiel mit unbenannten Schl�sseln

Beschreibung:
Version Beschreibung
5.5.0

Änderungen wurden durchgeführt, um diese Funktion in Übereinstimmung mit Perl zu bringen:

Der "a" Code erhält nun abschliessende NULL Bytes.

Der "A" Code entfernt nun alle abschliessenden ASCII Whitespaces (Leerzeichen, Tabs, Zeilenvorschübe, Wagenrückläufe und NULL Bytes).

Der "Z" Code wurde für mit NULL aufgefüllte Zeichenketten hinzugefügt, und entfernt abschliessende NULL Bytes.

<?php
$binarydata = "\x32\x42\x00\xa0";
$array = unpack("c2/n", $binarydata);
var_dump($array);
?>



Eingabe:
Das Ergebnis Array wird die Elemente "1" mit dem Wert 160 und "2" mit 66 enthalten. Der erste Wert vom Symbol c wurde mit dem Wert vom Symbol n überschrieben.

Beschreibung:
Version Beschreibung
5.5.0

Änderungen wurden durchgeführt, um diese Funktion in Übereinstimmung mit Perl zu bringen:

Der "a" Code erhält nun abschliessende NULL Bytes.

Der "A" Code entfernt nun alle abschliessenden ASCII Whitespaces (Leerzeichen, Tabs, Zeilenvorschübe, Wagenrückläufe und NULL Bytes).

Der "Z" Code wurde für mit NULL aufgefüllte Zeichenketten hinzugefügt, und entfernt abschliessende NULL Bytes.

Sonstige-Funktionen