オリジナルアプリを作成している者で、そのアプリにTwitter認証機能(Twitterアカウントでログインする機能)を実装しようと下記の記事を参考にやってみました
しかし、下の画像のように連携アプリの認証のページに飛んで認証画面にも行けるのですが、なぜかログインはされず新規登録画面(メールアドレスやパスワードなどを設定してアカウント登録する画面)に飛んでしまうという問題が起きています
発生している問題・エラーメッセージ
何が問題でこのようなことが起きているのか調べるためにdevelopment.logをみたところ下のようなlogが出ていました
Started GET "/auth/twitter" for ::1 at 2020-03-05 20:50:00 +0900 Started GET "/auth/twitter" for ::1 at 2020-03-05 20:50:01 +0900 Started GET "/auth/twitter/callback?oauth_token=30hf1QAAAAABCbykAAABcKqH9Ow&oauth_verifier=KPjtG1Ir5OAoaM80SsA26aC8Iv255QbG" for ::1 at 2020-03-05 20:50:54 +0900 Processing by UsersController#create as HTML Parameters: {"oauth_token"=>"30hf1QAAAAABCbykAAABcKqH9Ow", "oauth_verifier"=>"KPjtG1Ir5OAoaM80SsA26aC8Iv255QbG", "provider"=>"twitter"} [1m[36mUser Load (0.2ms)[0m [1m[34mSELECT "users".* FROM "users" WHERE "users"."id" IS NULL LIMIT ?[0m [["LIMIT", 1]] ↳ app/controllers/application_controller.rb:5 [1m[35m (0.1ms)[0m [1m[36mbegin transaction[0m ↳ app/controllers/users_controller.rb:28 [1m[36mUser Exists (0.3ms)[0m [1m[34mSELECT 1 AS one FROM "users" WHERE "users"."email" IS NULL LIMIT ?[0m [["LIMIT", 1]] ↳ app/controllers/users_controller.rb:28 [1m[35m (0.1ms)[0m [1m[31mrollback transaction[0m ↳ app/controllers/users_controller.rb:28 Rendering users/new.html.erb within layouts/application Rendered users/new.html.erb within layouts/application (0.7ms) Completed 200 OK in 32ms (Views: 25.1ms | ActiveRecord: 0.6ms)
該当のソースコード
**controllers/users_controller.rb** class UsersController < ApplicationController 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 show @user = User.find_by(id: params[:id]) @post = Post.where(user_id: @user.id) end def new @user = User.new end def create @user = User.new( name: params[:name], email: params[:email], image_name: "pile-up3.jpg", password: params[:password] ) if @user.save session[:user_id] = @user.id redirect_to("/users/#{@user.id}") else render("users/new") end end def edit @user = User.find_by(id: params[:id]) end def update @user = User.find_by(id: params[:id]) @user.name = params[:name] @user.email = params[:email] if params[:image] @user.image_name = "#{@user.id}.jpg" image = params[:image] File.binwrite("public/user_images/#{@user.image_name}",image.read) end if @user.save redirect_to("/users/#{@user.id}") else render("users/edit") 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 redirect_to("/users/#{@user.id}") else @error_message = "メールアドレスまたはパスワードが間違っています" @email = params[:email] @password = params[:password] render("users/login_form") end end def logout session[:user_id] = nil redirect_to("/login") end def ensure_correct_user if @current_user.id != params[:id].to_i flash[:notice] = "権限がありません" redirect_to("/posts/index") end end end
**.env** TWITTER_CONSUMER_KEY = "Consumer Key" TWITTER_CONSUMER_SECRET = "Consumer Secret"
**secrets.yml** default_twitter: &default_twitter twitter_api_key: <%= ENV["TWITTER_CONSUMER_KEY"] %> twitter_api_secret: <%= ENV["TWITTER_CONSUMER_SECRET"] %> development: secret_key_base: #最初から記入されているはず <<: *default_twitter test: secret_key_base: #最初から記入されているはず <<: *default_twitter production: secret_key_base: <%= ENV["SECRET_KEY_BASE"] %> twitter_api_key: <%= ENV["TWITTER_CONSUMER_KEY"] %> twitter_api_secret: <%= ENV["TWITTER_CONSUMER_SECRET"] %>
**initializers/omniauth.rb** Rails.application.config.middleware.use OmniAuth::Builder do provider :twitter, ENV['TWITTER_CONSUMER_KEY'], ENV['TWITTER_CONSUMER_SECRET'] end
**model/twitter.rb** class Twitter < ApplicationRecord def self.find_or_create_from_auth_hash(auth_hash) provider = auth_hash[:provider] uid = auth_hash[:uid] name = auth_hash[:info][:name] image_url = auth_hash[:info][:image] self.find_or_create_by(provider: provider,uid: uid) do |user| user.username = name user.image_url = image_url end end end
**controllers/twitter_controller.rb** class TwitterController < ApplicationController def create user = User.find_or_create_from_auth_hash(request.env['omniauth.auth']) if user session[:user_id] = user.id redirect_to '/posts/index', notice: "ログインしました。" else redirect_to root_path, notice: "失敗しました。" end end end
**route.rb** get 'auth/:provider/callback' => 'users#create' root 'home#top'
試したこと
また、route.rbの get 'auth/:provider/callback' => 'users#create'を get 'auth/:provider/callback' => 'twitter#create'に変えてみたのですが
OAuth::Unauthorized 401 Authorization Required
というエラーが出て認証できませんでした
あなたの回答
tips
プレビュー