類別 Digest::SHA2
SHA256、SHA384 和 SHA512 的元摘要提供者類別。
FIPS 180-2 描述 SHA2
摘要演算法家族。它定義了三種演算法
-
一種處理 512 位元組區塊並傳回 256 位元組摘要 (SHA256),
-
一種處理 1024 位元組區塊並傳回 384 位元組摘要 (SHA384),
-
一種處理 1024 位元組區塊並傳回 512 位元組摘要 (SHA512)。
範例¶ ↑
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..."
公開類別方法
Digest::SHA2.new(bitlen = 256) → digest_obj 按一下切換來源
使用指定的位元長度建立新的 SHA2
hash 物件。
有效的位元長度為 256、384 和 512。
# 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
公開執行個體方法
block_length → Integer 按一下切換來源
傳回摘要的區塊長度(以位元組為單位)。
Digest::SHA256.new.block_length * 8 # => 512 Digest::SHA384.new.block_length * 8 # => 1024 Digest::SHA512.new.block_length * 8 # => 1024
# File ext/digest/sha2/lib/sha2.rb, line 112 def block_length @sha2.block_length end
digest_length → Integer 按一下切換來源
傳回雜湊值(摘要)的長度(以位元組為單位)。
Digest::SHA256.new.digest_length * 8 # => 256 Digest::SHA384.new.digest_length * 8 # => 384 Digest::SHA512.new.digest_length * 8 # => 512
例如,Digest::SHA256 產生的摘要大小永遠是 32 位元組 (256 位元)。
# File ext/digest/sha2/lib/sha2.rb, line 130 def digest_length @sha2.digest_length end
reset → digest_obj 按一下切換來源
將摘要重設為初始狀態,並傳回 self。
# File ext/digest/sha2/lib/sha2.rb, line 79 def reset @sha2.reset self end
update(string) → digest_obj 按一下切換來源
使用指定的 string 更新摘要,並傳回 self。
# File ext/digest/sha2/lib/sha2.rb, line 89 def update(str) @sha2.update(str) self end
別名:<<