微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

生产中 Rails 中的 BCrypt::Errors::InvalidHash 错误

如何解决生产中 Rails 中的 BCrypt::Errors::InvalidHash 错误

我无法在我的生产网站上通过 LinkedIn 注册用户。它显示这样的错误

Completed 500 Internal Server Error in 202ms (ActiveRecord: 3.8ms)
[f842309d-189a-4edc-bafb-a6a567ea8fcd]   
[f842309d-189a-4edc-bafb-a6a567ea8fcd] BCrypt::Errors::InvalidHash (invalid hash):
[f842309d-189a-4edc-bafb-a6a567ea8fcd]   
[f842309d-189a-4edc-bafb-a6a567ea8fcd] app/models/user.rb:82:in `from_omniauth'
[f842309d-189a-4edc-bafb-a6a567ea8fcd] app/controllers/users/omniauth_callbacks_controller.rb:9:in `linkedin'

它在我的本地机器上运行良好。

class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
    def linkedin
      @user = User.from_omniauth(auth_hash,current_user,session)
      remember_me(@user)
      session[:user_id] = @user.id
      if !(@user.img_url == auth_hash.info.picture_url)
        @user.update_attributes(:img_url => auth_hash.info.picture_url)
      end
      if not @user.persisted?
        session["devise.linkedin_data"] = auth_hash
        render body: session.to_json
      end
      sign_in_and_redirect(:user,@user)
    end
end

用户模型

def self.from_omniauth(auth,signed_in=nil,session)
  user.password = Devise.friendly_token unless user.encrypted_password.present?
end

有人可以帮我理解这个错误以及我可以如何修复它吗?

解决方法

您是否尝试将 bcrypt 升级到 3.1.12

这是GITHUB ISSUE的链接

,

您是否正确设置了所有设计配置机密?检查生产服务器上的设计初始值设定项和 ENV 变量。我认为服务器缺少一个 ENV 变量来告诉 bcrypt 使用什么盐来存储密码

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。