Documentation
¶
Overview ¶
hash パッケージはハッシュ関数のためのインターフェースを提供します。
Example (BinaryMarshaler) ¶
package main
import (
"github.com/shogo82148/std/bytes"
"github.com/shogo82148/std/crypto/sha256"
"github.com/shogo82148/std/encoding"
"github.com/shogo82148/std/fmt"
"github.com/shogo82148/std/log"
)
func main() {
const (
input1 = "The tunneling gopher digs downwards, "
input2 = "unaware of what he will find."
)
first := sha256.New()
first.Write([]byte(input1))
marshaler, ok := first.(encoding.BinaryMarshaler)
if !ok {
log.Fatal("first does not implement encoding.BinaryMarshaler")
}
state, err := marshaler.MarshalBinary()
if err != nil {
log.Fatal("unable to marshal hash:", err)
}
second := sha256.New()
unmarshaler, ok := second.(encoding.BinaryUnmarshaler)
if !ok {
log.Fatal("second does not implement encoding.BinaryUnmarshaler")
}
if err := unmarshaler.UnmarshalBinary(state); err != nil {
log.Fatal("unable to unmarshal hash:", err)
}
first.Write([]byte(input2))
second.Write([]byte(input2))
fmt.Printf("%x\n", first.Sum(nil))
fmt.Println(bytes.Equal(first.Sum(nil), second.Sum(nil)))
}
Output: 57d51a066f3a39942649cd9a76c77e97ceab246756ff3888659e6aa5a07f4a52 true
Index ¶
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Cloner ¶ added in v1.25.0
Clonerは状態をクローンできるハッシュ関数で、 同等で独立した状態を持つ値を返します。
標準ライブラリのすべての Hash 実装は、GOFIPS140=v1.0.0が設定されていない限り、 このインターフェースを実装しています。
ハッシュが実行時にのみクローン可能かどうかを判断できる場合(例:別のハッシュをラップしている場合)、 CloneはErrUnsupportedをラップしたエラーを返すことがあります。 それ以外の場合、Cloneは常にnilエラーを返さなければなりません。
type Hash ¶
Hashはすべてのハッシュ関数で実装される共通のインターフェースです。
標準ライブラリのハッシュ実装(例:hash/crc32 や crypto/sha256)は、encoding.BinaryMarshaler、encoding.BinaryAppender、 encoding.BinaryUnmarshaler、および Cloner インターフェースを実装しています。ハッシュ実装の マーシャリングにより、その内部状態を保存し、以前にハッシュに書き込まれたデータを 再書き込みすることなく、後で追加処理に使用することができます。 ハッシュ状態には、入力の一部が元の形で含まれている可能性があり、 ユーザーは可能なセキュリティ上の影響を処理することが期待されます。
互換性:ハッシュまたは暗号パッケージへの将来の変更は、 以前のバージョンでエンコードされた状態を保持することを目指します。 つまり、パッケージのリリースバージョンは、 以前のリリースバージョンで書かれたデータをデコードすることができるはずです。 ただし、セキュリティ修正などの問題により、異なる結果となる場合があります。 背景については、Goの互換性文書を参照してください:https://golang.org/doc/go1compat
Directories
¶
| Path | Synopsis |
|---|---|
|
adler32パッケージはAdler-32チェックサムを実装しています。
|
adler32パッケージはAdler-32チェックサムを実装しています。 |
|
crc32パッケージは32ビットの巡回冗長検査 (CRC-32) チェックサムを実装しています。
|
crc32パッケージは32ビットの巡回冗長検査 (CRC-32) チェックサムを実装しています。 |
|
crc64パッケージは64ビットの巡回冗長検査(CRC-64)チェックサムを実装しています。
|
crc64パッケージは64ビットの巡回冗長検査(CRC-64)チェックサムを実装しています。 |
|
fnvパッケージは、 Glenn Fowler、Landon Curt Noll、およびPhong Voによって作成された FNV-1およびFNV-1aという非暗号化ハッシュ関数を実装しています。
|
fnvパッケージは、 Glenn Fowler、Landon Curt Noll、およびPhong Voによって作成された FNV-1およびFNV-1aという非暗号化ハッシュ関数を実装しています。 |
|
Package maphashはバイトシーケンスと比較可能な値に対するハッシュ関数を提供します。
|
Package maphashはバイトシーケンスと比較可能な値に対するハッシュ関数を提供します。 |