Odpowiedzi:
require 'digest/sha1'
Digest::SHA1.hexdigest 'foo'
Digest::SHA1.base64digest 'foo'
Digest
jest częścią Ruby Standard Library ( ruby-doc.org/stdlib-1.9.2/libdoc/digest/rdoc/index.html ). Zawiera implementacje algorytmów wyznaczania wartości skrótu SHA1, SHA2, MD5 i innych.
W przypadku skrótu zakodowanego w Base64, aby zweryfikować podpis Oauth, użyłem
require 'base64'
require 'hmac-sha1'
Base64.encode64((HMAC::SHA1.new('key') << 'base').digest).strip
Stworzyłem klejnot pomocnika, który jest prostym opakowaniem wokół kodu sha1
require 'rickshaw'
> Rickshaw::SHA1.hash('LICENSE.txt')
=> "4659d94e7082a65ca39e7b6725094f08a413250a"
> "hello world".to_sha1
=> "2aae6c35c94fcfb415dbe95f408b9ce91ee846ed"
Gdzie „serialize” to jakaś funkcja użytkownika zdefiniowana w innym miejscu.
def generateKey(data)
return Digest::SHA1.hexdigest ("#{serialize(data)}")
end
require 'digest/sha1'
, aby użyć SHA1
metody.