OpenSSL::HMAC
类 OpenSSL :: HMAC
家长:对象 (Parent:Object)
OpenSSL :: HMAC 允许计算基于哈希的消息认证码(HMAC)。它是一种消息认证码(MAC),涉及与密钥组合的散列函数。HMAC可以用来验证消息的完整性以及真实性。
OpenSSL :: HMAC 与 OpenSSL :: Digest 具有相似的接口。
HMAC-SHA256 使用一次性接口
key = "key"
data = "message-to-be-authenticated"
mac = OpenSSL::HMAC.hexdigest("SHA256", key, data)
#=> "cddb0db23f469c8bf072b21fd837149bd6ace9ab771cceef14c9e517cc93282e"
HMAC-SHA256 使用增量接口
data1 = File.read("file1")
data2 = File.read("file2")
key = "key"
digest = OpenSSL::Digest::SHA256.new
hmac = OpenSSL::HMAC.new(key, digest)
hmac << data1
hmac << data2
mac = hmac.digest
公共类方法
摘要(摘要,键,数据)→aString显示源
以二进制字符串形式返回认证码。digest
参数必须是 OpenSSL :: Digest 的实例。
示例
key = 'key'
data = 'The quick brown fox jumps over the lazy dog'
digest = OpenSSL::Digest.new('sha1')
hmac = OpenSSL::HMAC.digest(digest, key, data)
#=> "\xDE|\x9B\x85\xB8\xB7\x8A\xA6\xBC\x8Az6\xF7\n\x90p\x1C\x9D\xB4\xD9"
static VALUE
ossl_hmac_s_digest(VALUE klass, VALUE digest, VALUE key, VALUE data)
{
unsigned char *buf;
unsigned int buf_len;
StringValue(key
StringValue(data
buf = HMAC(GetDigestPtr(digest), RSTRING_PTR(key), RSTRING_LENINT(key),
(unsigned char *)RSTRING_PTR(data), RSTRING_LEN(data), NULL, &buf_len
return rb_str_new((const char *)buf, buf_len
}
十六进制(摘要,键,数据)→aString显示源
以十六进制编码的字符串形式返回认证码。digest
参数必须是 OpenSSL :: Digest 的实例。
示例
key = 'key'
data = 'The quick brown fox jumps over the lazy dog'
digest = OpenSSL::Digest.new('sha1')
hmac = OpenSSL::HMAC.hexdigest(digest, key, data)
#=> "de7c9b85b8b78aa6bc8a7a36f70a90701c9db4d9"
static VALUE
ossl_hmac_s_hexdigest(VALUE klass, VALUE digest, VALUE key, VALUE data)
{
unsigned char buf[EVP_MAX_MD_SIZE];
unsigned int buf_len;
VALUE ret;
StringValue(key
StringValue(data
if (!HMAC(GetDigestPtr(digest), RSTRING_PTR(key), RSTRING_LENINT(key),
(unsigned char *)RSTRING_PTR(data), RSTRING_LEN(data),
buf, &buf_len))
ossl_raise(eHMACError, "HMAC"
ret = rb_str_new(NULL, buf_len * 2
ossl_bin2hex(buf, RSTRING_PTR(ret), buf_len
return ret;
}
新(密钥,摘要)→hmac显示源文件
返回使用密钥和摘要算法设置的 OpenSSL :: HMAC 实例。该实例表示处理任何数据之前的消息认证代码的初始状态。要使用它处理数据,请使用实例方法update将您的数据作为参数。
示例
key = 'key'
digest = OpenSSL::Digest.new('sha1')
instance = OpenSSL::HMAC.new(key, digest)
#=> f42bb0eeb018ebbd4597ae7213711ec60760843f
instance.class
#=> OpenSSL::HMAC
关于比较的说明
两个实例在比较时不会相同,即使它们具有相同的值。使用to_s或hexdigest返回实例表示的认证码。例如:
other_instance = OpenSSL::HMAC.new('key', OpenSSL::Digest.new('sha1'))
#=> f42bb0eeb018ebbd4597ae7213711ec60760843f
instance
#=> f42bb0eeb018ebbd4597ae7213711ec60760843f
instance == other_instance
#=> false
instance.to_s == other_instance.to_s
#=> true
static VALUE
ossl_hmac_initialize(VALUE self, VALUE key, VALUE digest)
{
HMAC_CTX *ctx;
StringValue(key
GetHMAC(self, ctx
HMAC_Init_ex(ctx, RSTRING_PTR(key), RSTRING_LENINT(key),
GetDigestPtr(digest), NULL
return self;
}
公共实例方法
<<(p1)
别名为:更新
摘要→字符串 显示源文件
返回实例表示为二进制字符串的认证码。
示例
instance = OpenSSL::HMAC.new('key', OpenSSL::Digest.new('sha1'))
#=> f42bb0eeb018ebbd4597ae7213711ec60760843f
instance.digest
#=> "\xF4+\xB0\xEE\xB0\x18\xEB\xBDE\x97\xAEr\x13q\x1E\xC6\a`\x84?"
static VALUE
ossl_hmac_digest(VALUE self)
{
HMAC_CTX *ctx;
unsigned int buf_len;
VALUE ret;
GetHMAC(self, ctx
ret = rb_str_new(NULL, EVP_MAX_MD_SIZE
hmac_final(ctx, (unsigned char *)RSTRING_PTR(ret), &buf_len
assert(buf_len <= EVP_MAX_MD_SIZE
rb_str_set_len(ret, buf_len
return ret;
}
十六进制→字符串 显示源
返回实例表示为十六进制编码字符串的验证码。
static VALUE
ossl_hmac_hexdigest(VALUE self)
{
HMAC_CTX *ctx;
unsigned char buf[EVP_MAX_MD_SIZE];
unsigned int buf_len;
VALUE ret;
GetHMAC(self, ctx
hmac_final(ctx, buf, &buf_len
ret = rb_str_new(NULL, buf_len * 2
ossl_bin2hex(buf, RSTRING_PTR(ret), buf_len
return ret;
}
还有别名:检查,to_s
inspect()
别名为:十六进制
重置→自己 显示来源
返回self
到第一次初始化时的状态,并清除所有已处理的数据。
示例
data = "The quick brown fox jumps over the lazy dog"
instance = OpenSSL::HMAC.new('key', OpenSSL::Digest.new('sha1'))
#=> f42bb0eeb018ebbd4597ae7213711ec60760843f
instance.update(data)
#=> de7c9b85b8b78aa6bc8a7a36f70a90701c9db4d9
instance.reset
#=> f42bb0eeb018ebbd4597ae7213711ec60760843f
static VALUE
ossl_hmac_reset(VALUE self)
{
HMAC_CTX *ctx;
GetHMAC(self, ctx
HMAC_Init_ex(ctx, NULL, 0, NULL, NULL
return self;
}
to_s()
别名为:十六进制
更新(字符串)→自我 显示来源
返回值self
更新为要验证的消息。可以通过消息块重复调用。
示例
first_chunk = 'The quick brown fox jumps '
second_chunk = 'over the lazy dog'
instance.update(first_chunk)
#=> 5b9a8038a65d571076d97fe783989e52278a492a
instance.update(second_chunk)
#=> de7c9b85b8b78aa6bc8a7a36f70a90701c9db4d9
static VALUE
ossl_hmac_update(VALUE self, VALUE data)
{
HMAC_CTX *ctx;
StringValue(data
GetHMAC(self, ctx
HMAC_Update(ctx, (unsigned char *)RSTRING_PTR(data), RSTRING_LEN(data)
return self;
}
另外别名为:<<