sodium_crypto_generichash_init

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

説明

string sodium_crypto_generichash_init(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($state32);
var_dump(sodium_bin2hex($final));
$allAtOnce sodium_crypto_generichash(implode(''$messages));
var_dump(sodium_bin2hex($allAtOnce));
?>

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

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