質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

915閲覧

RubyonRails ログインができない場合の解決方法

TOMSOYA

総合スコア23

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2019/04/30 01:43

編集2019/04/30 03:24

前提・実現したいこと

プログラミング初心者です。練習としてTwitterのようなサービスを作っているのですが、ログインができなくて困っています。

発生している問題・エラーメッセージ

ログインしようとすると”メールアドレスまたはパスワードが間違っています。”というメッセージが出てしまってログインできません。
メールアドレスもパスワードも間違っていないのですがエラーが出てしまいます。

該当のソースコード

class UsersController < ApplicationController protect_from_forgery except: :logout before_action :authenticate_user, {only: [:index, :show, :edit, :update]} before_action :forbid_login_user, {only: [:new, :create, :login_form, :login]} before_action :ensure_correct_user, {only: [:edit, :update]} def create @user = User.new(user_params) @user.image_name = "default_user.jpg" @user.profile = "こんにちは!" if @user.save session[:user_id] = @user.id flash[:notice] = "ユーザー登録が完了しました" redirect_to("/users/#{@user.id}") else render("users/new") end end def login_form end def login @user = User.find_by(email: params[:email]) if @user && @user.authenticate(params[:password]) session[:user_id] = @user.id flash[:notice] = "ログインしました" redirect_to("/posts/index") else @error_message = "メールアドレスまたはパスワードが間違っています" @email = params[:email] @password = params[:password] render("users/login_form") end end def user_params params.require(:user).permit(:name, :email, :password, :password_confirmation, :image_name, :profile) end
#login_form.html.erb <div class="main users-new"> <div class="container"> <div class="form-heading">ログイン</div> <div class="form users-form"> <div class="form-body"> <% if @error_message %> <div class="form-error"> <%= @error_message %> </div> <% end %> <%= form_tag("/login") do %> <p>メールアドレス</p> <input name="email" value="<%= @email %>"> <p>パスワード</p> <input type="password" name="password" value="<%= @password %>"> <input type="submit" value="ログイン"> <% end %> </div> </div> </div> </div>
get "login" => "users#login_form" post "login" => "users#login" post "logout" => "users#logout"
user = User.create(name: "taro", email: "taro@example.com", password: "foo", password_confirmation: "foo") (0.1ms) begin transaction User Exists (0.2ms) SELECT 1 AS one FROM "users" WHERE "users"."email" = ? LIMIT ? [["email", "taro@example.com"], ["LIMIT", 1]] User Create (1.6ms) INSERT INTO "users" ("name", "email", "created_at", "updated_at", "password_digest") VALUES (?, ?, ?, ?, ?) [["name", "taro"], ["email", "taro@example.com"], ["created_at", "2019-04-28 21:47:51.443175"], ["updated_at", "2019-04-28 21:47:51.443175"], ["password_digest", "$2a$10$A6kLyqa5sEYJhYGKNL1aUOX3kaYAReqq4HYzERSEuO55.TPn7r15S"]] (7.8ms) commit transaction => #<User:0x005608d9b11718 id: 1, name: "taro", email: "taro@example.com", created_at: Sun, 28 Apr 2019 21:47:51 UTC +00:00, updated_at: Sun, 28 Apr 2019 21:47:51 UTC +00:00, image_name: nil, password_digest: "$2a$10$A6kLyqa5sEYJhYGKNL1aUOX3kaYAReqq4HYzERSEuO55.TPn7r15S", profile: nil> [2] pry(main)> user.authenticate("foo") => #<User:0x005608d9b11718 id: 1, name: "taro", email: "taro@example.com", created_at: Sun, 28 Apr 2019 21:47:51 UTC +00:00, updated_at: Sun, 28 Apr 2019 21:47:51 UTC +00:00, image_name: nil, password_digest: "$2a$10$A6kLyqa5sEYJhYGKNL1aUOX3kaYAReqq4HYzERSEuO55.TPn7r15S", profile: nil>
class User < ApplicationRecord has_secure_password validations: true mount_uploader :image, ImageUploader validates :name,{presence: true} validates :email,{presence: true, uniqueness: true} has_many :posts, dependent: :destroy def posts return Post.where(user_id: self.id) end end

試したこと

新規登録した際の情報をrails consoleで確認してみるとしっかり入っていたのでDBに保存はされているとは思うのですが…
一致しないということはログインする際に必要な情報がDBにないということだと思うのですが解決方法がわからなくて困っています!
よろしくお願いします!!

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

iwamot

2019/04/30 02:08

Userクラスのソースと、「rails consoleで確認」なさったときの実行コマンドと出力結果を追記していただくことは可能でしょうか。
TOMSOYA

2019/04/30 03:25

回答ありがとうございます! 追加しました!
iwamot

2019/04/30 03:48

うーん、問題なさそうですね。 UserControllerのloginメソッド内で「@user」および「@user.authenticate(params[:password])」がどんな値になっているか、デバッグログを出力するなどして地道に調べてみるのがよいのではないでしょうか。
TOMSOYA

2019/04/30 04:18

回答ありがとうございます! サーバーとテキストエディタを全て再起動すると解決しました! もしかしたらどこかに不具合があったのかもしれませんが、コードは間違ってなかったみたいで良かったです!
iwamot

2019/04/30 04:36 編集

よかったです。ご自身で回答を書いて、ベストアンサーに選ぶと、他の方の参考になるかもしれません。
TOMSOYA

2019/04/30 05:07

本当にありがとうございました! はい、そうします!
guest

回答1

0

自己解決

コードに問題はなさそうだったのでサーバーとテキストエディタを再起動したら解決しました!

投稿2019/04/30 05:09

TOMSOYA

総合スコア23

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問