Função unpack() do PHP
Definição e uso
A função unpack() desempacota dados de uma string binária.
Sintaxe
unpack(format,data)
Parâmetro | Descrição |
---|---|
format | Obrigatório. Define o formato usado para desempacotar os dados. |
data | Opcional. Define os dados binários desempacotados. |
Valores possíveis do parâmetro format:
- a - String preenchida com NULO
- A - String preenchida com ESPAÇO
- h - Stringa esadecimale, nibble mais baixo primeiro
- H - Stringa esadecimale, nibble mais alto primeiro
- c - signed char
- C - unsigned char
- s - signed short (sempre 16 bits, ordem de bytes da máquina)
- S - unsigned short (sempre 16 bits, ordem de bytes da máquina)
- n - unsigned short (sempre 16 bits, ordem de bytes big endian)
- v - unsigned short (sempre 16 bits, ordem de bytes little endian)
- i - signed integer (tamanho e ordem de bytes dependente da máquina)
- I - unsigned integer (tamanho e ordem de bytes dependente da máquina)
- l - signed long (sempre 32 bits, ordem de bytes da máquina)
- L - unsigned long (sempre 32 bits, ordem de bytes da máquina)
- N - unsigned long (sempre 32 bits, ordem de bytes big endian)
- V - unsigned long (sempre 32 bits, ordem de bytes little endian)
- f - float (tamanho e representação dependentes da máquina)
- d - double (tamanho e representação dependentes da máquina)
- x - Byte NUL
- X - Voltar um byte
- @ - Preencher com NUL até a posição absoluta
Exemplo
Exemplo 1
<?php $data = "PHP"; print_r(unpack("C*",$data)); ?>
Saída:
Array ( [1] => 80 [2] => 72 [3] => 80 )
Exemplo 2
<?php $data = "PHP"; print_r(unpack("C*myint",$data)); ?>
Saída:
Array ( [myint1] => 80 [myint2] => 72 [myint3] => 80 )
Exemplo 3
<?php $bin = pack("c2n2",0x1234,0x5678,65,66); print_r(unpack("c2chars/n2int",$bin)); ?>
Saída:
Array ( [chars1] => 52 [chars2] => 120 [int1] => 65 [int2] => 66 )