#実現・解決したいこと
BCryptのエラーを解決し、
has_secure_passwordを用いたログイン機能の実装
#問題点
エラー文
BCrypt::Errors::InvalidHash in UsersController#sign_in invalid hash
if文の条件の行でエラー表示されます。
users_controller↓
if @user && @user.authenticate(params[:password])← ← ← session[:user_id] = @user.id redirect_to("/users/sign_up_form") else
#調べたこと
teratailで同様の質問を探し、Userパスワードが入っていない状態の User が出来てしまったのが原因と考えられます
#####引用
BCrypt::Errors::InvalidHash は、わりとよくあるエラーです。
「InvalidHash」の「Hash」は Ruby の組み込みクラスのハッシュ(他の言語でいう連想配列)とは違って、パスワードをハッシュ化した文字列のことを指しています。
データベースに格納されているそれが、どこか異常なんです。
原因は、いくつかあります。
以前、bcrypt のバージョンが上がって、ハッシュ化の形式が変わったためにこのエラーが出たことがあったように記憶しています。
また、開発途中で、パスワードが入っていない状態の User が出来てしまっている場合も出るようです(たぶん)。
もし現状のデータベースのデータを温存しなくてよいなら、User の作成からやりなおすと直るかもしれません。
#試したこと
Userモデルを作り直しましたが、エラーは解決しませんでした。
#環境・バージョン
Ruby on Rails
Rails 6.0.2.1
Using bcrypt 3.1.13
Using bcrypt-ruby 3.1.5 (x64-mingw32)
Windows
#考えていること
モデルの作り直し方が間違っているのかもしれません。Userモデルを作る際に、name,emailカラムを作り、後からpassword_digestを追加したのでそこが原因なのではと考えています。
回答2件
あなたの回答
tips
プレビュー