array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ja', ), 'this' => array ( 0 => 'function.hash-hmac.php', 1 => 'hash_hmac', ), 'up' => array ( 0 => 'ref.hash.php', 1 => 'Hash 関数', ), 'prev' => array ( 0 => 'function.hash-hmac-file.php', 1 => 'hash_hmac_file', ), 'next' => array ( 0 => 'function.hash-init.php', 1 => 'hash_init', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ja', 'path' => 'reference/hash/functions/hash-hmac.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 5 >= 5.1.2, PHP 7, PHP 8, PECL hash >= 1.1)
hash_hmac — HMAC 方式を使用してハッシュ値を生成する
algo
選択したアルゴリズムの名前 (すなわち "md5"、"sha256"、"haval160,4" など…)。 サポートするアルゴリズムの一覧は hash_hmac_algos() を参照ください。
data
ハッシュするメッセージ。
key
HMAC 方式でのメッセージダイジェストを生成するために使用する 共有の秘密鍵。
binary
binary
が true に設定されていない場合は、
メッセージダイジェストの計算結果を小文字の 16 進数値形式の文字列で
返します。もし true に設定されていた場合は、メッセージダイジェストが
そのままのバイナリ形式で返されます。
algo
が不明な場合や、
暗号に適さないハッシュ関数の場合、
ValueError がスローされます。
バージョン | 説明 |
---|---|
8.0.0 |
algo が不明な場合や、
暗号に適さないハッシュ関数の場合に
ValueError をスローするようになりました。
これより前のバージョンでは、false を返していました。
|
7.2.0 | 暗号に適さないハッシュ関数 (adler32, crc32, crc32b, fnv132, fnv1a32, fnv164, fnv1a64, joaat) は使えなくなりました。 |
例1 hash_hmac() の例
<?php
echo hash_hmac('sha256', 'The quick brown fox jumped over the lazy dog.', 'secret');
?>
上の例の出力は以下となります。
9c5c42422b03f0ee32949920649445e417b2c634050833c5165704b825c2a53b