首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Digest

该模块为消息摘要库提供了一个框架。

你可能想了解OpenSSL :: Digest,因为它支持更多的算法。

密码散列函数是一个接收数据并返回固定位串的过程:散列值,也称为摘要。散列函数也称为单向函数,它很容易从消息中计算摘要,但从摘要生成消息是不可行的。

例子

代码语言:javascript
复制
require 'digest'

# Compute a complete digest
Digest::SHA256.digest 'message'       #=> "\xABS\n\x13\xE4Y..."

sha256 = Digest::SHA256.new
sha256.digest 'message'               #=> "\xABS\n\x13\xE4Y..."

# Other encoding formats
Digest::SHA256.hexdigest 'message'    #=> "ab530a13e459..."
Digest::SHA256.base64digest 'message' #=> "q1MKE+RZFJgr..."

# Compute digest by chunks
md5 = Digest::MD5.new
md5.update 'message1'
md5 << 'message2'                     # << is an alias for update

md5.hexdigest                         #=> "94af09c09bb9..."

# Compute digest for a file
sha256 = Digest::SHA256.file 'testfile'
sha256.hexdigest

此外,摘要可以以“bubble babble”格式编码为辅音和元音的序列,其比十六进制摘要更易识别和比较。

代码语言:javascript
复制
require 'digest/bubblebabble'

Digest::SHA256.bubblebabble 'message' #=> "xopoh-fedac-fenyh-..."

摘要算法

不同的摘要算法(或散列函数)可用:

MD5

请参阅RFC 1321 MD5消息摘要算法

RIPEMD-160

SHA1

请参阅FIPS 180安全散列标准。

SHA2系列

请参阅FIPS 180安全散列标准,其中定义了以下算法:

  • SHA512
  • SHA384
  • SHA256

常量

REQUIRE_MUTEX

A mutex for Digest().

公共类方法

bubblebabble(string) → bubblebabble_string Show source

返回给定字符串 的BubbleBabble编码版本。

代码语言:javascript
复制
static VALUE
rb_digest_s_bubblebabble(VALUE klass, VALUE str)
{
    return bubblebabble_str_new(str);
}

hexencode(string) → hexencoded_string Show source

生成给定字符串 的十六进制编码版本。

代码语言:javascript
复制
static VALUE
rb_digest_s_hexencode(VALUE klass, VALUE str)
{
    return hexencode_str_new(str);
}

扫码关注腾讯云开发者

领取腾讯云代金券

http://www.vxiaotou.com