class Digest::SHA2
Eine Meta-Digest-Provider-Klasse für SHA256, SHA384 und SHA512.
FIPS 180-2 beschreibt die SHA2-Familie von Digest-Algorithmen. Es definiert drei Algorithmen
-
einen, der mit Blöcken von 512 Bit arbeitet und einen 256-Bit-Digest zurückgibt (
SHA256), -
einen, der mit Blöcken von 1024 Bit arbeitet und einen 384-Bit-Digest zurückgibt (
SHA384), -
und einen, der mit Blöcken von 1024 Bit arbeitet und einen 512-Bit-Digest zurückgibt (
SHA512).
Beispiele
require 'digest' # Compute a complete digest Digest::SHA2.hexdigest 'abc' # => "ba7816bf8..." Digest::SHA2.new(256).hexdigest 'abc' # => "ba7816bf8..." Digest::SHA256.hexdigest 'abc' # => "ba7816bf8..." Digest::SHA2.new(384).hexdigest 'abc' # => "cb00753f4..." Digest::SHA384.hexdigest 'abc' # => "cb00753f4..." Digest::SHA2.new(512).hexdigest 'abc' # => "ddaf35a19..." Digest::SHA512.hexdigest 'abc' # => "ddaf35a19..." # Compute digest by chunks sha2 = Digest::SHA2.new # =>#<Digest::SHA2:256> sha2.update "ab" sha2 << "c" # alias for #update sha2.hexdigest # => "ba7816bf8..." # Use the same object to compute another digest sha2.reset sha2 << "message" sha2.hexdigest # => "ab530a13e..."
Öffentliche Klassenmethoden
Source
# File ext/digest/sha2/lib/sha2.rb, line 61 def initialize(bitlen = 256) case bitlen when 256 @sha2 = Digest::SHA256.new when 384 @sha2 = Digest::SHA384.new when 512 @sha2 = Digest::SHA512.new else raise ArgumentError, "unsupported bit length: %s" % bitlen.inspect end @bitlen = bitlen end
Erstellt ein neues SHA2-Hash-Objekt mit einer gegebenen Bitlänge.
Gültige Bitlängen sind 256, 384 und 512.
Öffentliche Instanzmethoden
Source
# File ext/digest/sha2/lib/sha2.rb, line 112 def block_length @sha2.block_length end
Gibt die Blocklänge des Digests in Bytes zurück.
Digest::SHA256.new.block_length * 8 # => 512 Digest::SHA384.new.block_length * 8 # => 1024 Digest::SHA512.new.block_length * 8 # => 1024
Source
# File ext/digest/sha2/lib/sha2.rb, line 130 def digest_length @sha2.digest_length end
Gibt die Länge des Hash-Wertes (des Digests) in Bytes zurück.
Digest::SHA256.new.digest_length * 8 # => 256 Digest::SHA384.new.digest_length * 8 # => 384 Digest::SHA512.new.digest_length * 8 # => 512
Beispielsweise sind Digests, die von Digest::SHA256 erzeugt werden, immer 32 Bytes (256 Bit) groß.
Source
# File ext/digest/sha2/lib/sha2.rb, line 79 def reset @sha2.reset self end
Setzt den Digest auf den Anfangszustand zurück und gibt self zurück.
Source
# File ext/digest/sha2/lib/sha2.rb, line 89 def update(str) @sha2.update(str) self end
Aktualisiert den Digest mit einem gegebenen *string* und gibt self zurück.