PHPerKaigi 2025

hash_update

(PHP 5 >= 5.1.2, PHP 7, PHP 8, PECL hash >= 1.1)

hash_updateアクティブなハッシュコンテキストにデータを投入する

説明

hash_update(HashContext $context, string $data): true

パラメータ

context

hash_init() が返すハッシュコンテキスト。

data

ハッシュダイジェストに含めるメッセージ。

戻り値

常に true を返します。

変更履歴

バージョン 説明
8.4.0 戻り値の型が bool ではなく true になりました。
7.2.0 リソースの代わりに HashContext を受け入れるようになりました。

参考

  • hash_init() - 段階的なハッシュコンテキストを初期化する
  • hash_update_file() - アクティブなハッシュコンテキストに、ファイルからデータを投入する
  • hash_update_stream() - アクティブなハッシュコンテキストに、オープンしているストリームから データを投入する
  • hash_final() - 段階的なハッシュ処理を終了し、出来上がったダイジェストを返す

add a note

User Contributed Notes 1 note

up
5
Dainichi
18 years ago
A simple example on incremental file hashing:

$fp = fopen($file, "r");
$ctx = hash_init('sha256');
while (!feof($fp)) {
$buffer = fgets($fp, 65536);
hash_update($ctx, $buffer);
}
$hash = hash_final($ctx, true);
fclose($fp);

While incremental hashing is quite slow, it's the easiest way to hash
- parts of large files: I.e., a 700MB avi video uses first x bytes to store metadata, so in order to hash the avi's data only, you have to fseek to data start and use incremental hashing
- streaming data if php just proxies the data
- whenever it's inadequate or impossible to store the data being hashed into memory (i.e. because of their size) or on disc.
To Top