跳至内容 跳至搜索

用于生成和派生随机密钥的实用程序。

方法
D
G
N

属性

[R] hash_digest_class

类公共方法

new(hash_digest_class: ActiveRecord::Encryption.config.hash_digest_class)

# File activerecord/lib/active_record/encryption/key_generator.rb, line 11
def initialize(hash_digest_class: ActiveRecord::Encryption.config.hash_digest_class)
  @hash_digest_class = hash_digest_class
end

实例公共方法

derive_key_from(password, length: key_length)

从给定密码派生密钥。密钥的字节大小将为:length(默认情况下为配置的Cipher长度)

生成的密钥将使用ActiveRecord::Encryption.key_derivation_salt的值进行加盐

# File activerecord/lib/active_record/encryption/key_generator.rb, line 38
def derive_key_from(password, length: key_length)
  ActiveSupport::KeyGenerator.new(password, hash_digest_class: hash_digest_class)
    .generate_key(key_derivation_salt, length)
end

generate_random_hex_key(length: key_length)

以十六进制格式返回随机密钥。密钥的字节大小将为:length(默认情况下为配置的Cipher长度)

十六进制格式便于将密钥表示为可打印文本。为了最大程度地利用字符空间,最好包含不可打印字符。十六进制格式确保生成的密钥可以用纯文本表示

要转换回具有所需长度的原始字符串

[ value ].pack("H*")
# File activerecord/lib/active_record/encryption/key_generator.rb, line 30
def generate_random_hex_key(length: key_length)
  generate_random_key(length: length).unpack("H*")[0]
end

generate_random_key(length: key_length)

返回一个随机密钥。密钥的字节大小将为:length(默认情况下为配置的Cipher长度)

# File activerecord/lib/active_record/encryption/key_generator.rb, line 16
def generate_random_key(length: key_length)
  SecureRandom.random_bytes(length)
end