sodium_crypto_generichash_init

ストリーミングのためにハッシュを初期化する

説明

string sodium_crypto_generichash_init(#[\SensitiveParameter]string $key = "", int $length = SODIUM_CRYPTO_GENERICHASH_BYTES)

ストリーミングハッシュAPI の初期化メソッドです。

パラメータ

key

ハッシュキー

length

ハッシュ関数に期待する出力の長さ

戻り値

生のバイナリ文字列としてシリアライズされた、 ハッシュステートを返します。

例1 sodium_crypto_generichash_init の例

<?php
$messages = [random_bytes(32), random_bytes(32), random_bytes(16)];
$state = sodium_crypto_generichash_init('', 32);
foreach ($messages as $message) {
    sodium_crypto_generichash_update($state, $message);
}
$final = sodium_crypto_generichash_final($state, 32);
var_dump(sodium_bin2hex($final));
$allAtOnce = sodium_crypto_generichash(implode('', $messages));
var_dump(sodium_bin2hex($allAtOnce));
?>

上の例の出力は、 たとえば以下のようになります。

string(64) "a2939a9163cb7c796ec28e01028489e72475c136b2697ea59e3e760ab4a8ab20"
string(64) "a2939a9163cb7c796ec28e01028489e72475c136b2697ea59e3e760ab4a8ab20"