小编Cha*_*ano的帖子

Rails 7 - ActiveSupport::MessageEncryptor

我将应用程序从 Rails 6.1 升级到了 Rails 7,但遇到了一个问题。

我使用 ActiveSupport::MessageEncryptor 加密了一些数据字段。我有我的代码来加密和解密下面。

当我创建新记录时没有问题。这些值已加密。然后,当我查看记录时,值被解密。

问题是我无法查看升级到 Rails 7 之前创建的任何记录。decrypt_and_verify 方法抛出 ActiveSupport::MessageEncryptor::InvalidMessage

请注意,ENV 值 KEY_GENERATOR_SECRET 和 KEY_GENERATOR_SALT 未更改。

我未能测试解密旧记录,并认为我做得很好 - 所以我已经将其推向生产环境(在 Heroku 上)。此问题存在于开发、测试和生产中。美好时光。

感谢您的帮助,查理

  # ----------------------------------------------------------------

  # encrypt a value
  def encrypt_value(obj_value)

    # create the key from a combination of
    # our secret passcode + unique salt
    key = ActiveSupport::KeyGenerator.new(ENV['KEY_GENERATOR_SECRET']).generate_key(ENV['KEY_GENERATOR_SALT'], 32)

    # encrypt the objects value
    ActiveSupport::MessageEncryptor.new(key).encrypt_and_sign(obj_value)

  end

  # ----------------------------------------------------------------

  # decrypt a value
  def decrypt_value(encrypted_value)

    # if nothing to encrypt,
    # return an empty string …
Run Code Online (Sandbox Code Playgroud)

ruby ruby-on-rails ruby-on-rails-7

5
推荐指数
1
解决办法
5030
查看次数

标签 统计

ruby ×1

ruby-on-rails ×1

ruby-on-rails-7 ×1