hex2bin

関数の概要

hex2bin関数は、PHPで16進数(ヘキサデシマル)文字列をバイナリデータに変換するための関数です。16進数で表現された文字列を、その対応するバイト列に変換したいときに使用します。例えば、16進の文字列をそのままバイナリファイルとして扱いたい場合や、暗号化やハッシュ処理の前処理で変換が必要な場合に役立ちます。

パラメータの説明

  • string $hex_string:変換対象の16進数文字列を指定します。文字列の長さは偶数である必要があり、0-9、a-f、A-Fの文字だけで構成されている必要があります。

戻り値

成功すると、16進数で表された文字列を対応するバイナリ文字列に変換して返します。入力文字列が不正な場合(偶数長でない、または16進数以外の文字が含まれるなど)には false を返します。

使用例

基本的な使い方

<?php
$hex = "48656c6c6f20576f726c64"; // "Hello World"の16進数表現
$binary = hex2bin($hex);
echo $binary; // Hello World
?>

この例では、文字列 “Hello World” を16進数表現の文字列から元のテキストに戻しています。

バイナリデータとしてファイルに保存する例

<?php
$hex = "ffd8ffe000104a464946"; // JPEGファイルのヘッダーの一部
$binary = hex2bin($hex);
file_put_contents('image_header.bin', $binary);
?>

16進数表現されたJPEGファイルのヘッダーをバイナリファイルとして保存する例です。

不正な16進文字列の扱い

<?php
$invalidHex = "123";  // 奇数長の文字列

$result = hex2bin($invalidHex);
if ($result === false) {
    echo "無効な16進数文字列です。";
}
?>

奇数長や不正な文字列の場合には false が返ることを確認し、エラーハンドリングを行う例です。

関連する関数

  • bin2hex:バイナリデータを16進数文字列に変換する関数
  • pack:フォーマット指定に基づきデータをバイナリ形式に変換する関数
  • unpack:バイナリデータを指定のフォーマットに従い配列に展開する関数

まとめ

hex2binは、16進数の文字列をバイナリデータに変換するのに非常に便利なPHP関数です。ファイル操作やデータ処理、暗号化などの場面で活用できます。入力には偶数長かつ正しい16進文字列を使用する必要があり、不正な場合は false が返るのでエラーチェックを忘れないようにしましょう。関連関数と組み合わせることで、より効率的なデータ操作が可能になります。