Ruby(Ruby on Rails)でオリジナルアプリを作っているものです
アプリのログイン機能のひとつにTwitter認証を追加しようと
https://qiita.com/keiya01/items/c96a0393c76f5560ee41
https://qiita.com/sato-takuya/items/2c66e57d67e754bb1f79
などの記事を参考に試してみたのですが、OAuth::Unauthorized 401 Unauthorizedというエラーが出てしまい解消できません
発生している問題・エラーメッセージ
OAuth::Unauthorized 401 Authorization Required Extracted source (around line #236): self.token_request(http_method, uri.path, token, request_options, arguments) when (400..499) raise OAuth::Unauthorized, response else response.error! end
該当のソースコード
**.env** TWITTER_CONSUMER_KEY = "At9i5eUDGCWOHtds3yCmQnl8U" TWITTER_CONSUMER_SECRET = "DAv88lsRRUBwNBWAdPiVKeEYM2QxP6uZHTtjIIk2V50HlwooOO"
**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"] %>
**omniauth.rb** Rails.application.config.middleware.use OmniAuth::Builder do provider :twitter, "At9i5eUDGCWOHtds3yCmQnl8U", "DAv88lsRRUBwNBWAdPiVKeEYM2QxP6uZHTtjIIk2V50HlwooOO" end
**models/twitter.rb** class User < ApplicationRecord def self.find_or_create_from_auth_hash(auth_hash) provider = auth_hash[:provider] #providerはどのサービスで認証したのかを見分けるもの uid = auth_hash[:uid] name = auth_hash[:info][:name] image_url = auth_hash[:info][:image] #find_or_create_by()は()の中の条件のものが見つければ取得し、なければ新しく作成するというメソッド self.find_or_create_by(provider: provider,uid: uid) do |user| user.username = name user.image_url = image_url end end end
**controllers/users_controller.rb** 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 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
試したこと
https://qiita.com/hirokishirai/items/5a43977a38ecd922bfb9
上の記事を参考にして
・CallbackURLをいれる(下の画像の通りです)
・API_KEYとAPI_SECRETが正しいかの確認
・アプリがTwitterからSuspendされていないか確認(されていませんでした)
という3点を確認してみましたが特におかしな点はなかったです(CallbackURLは
https://developer.a-blogcms.jp/tips/twitter/setting.html
を参考に設定したのですが間違っていたらすみません)
どこかおかしい点にお気づきの方がいらっしゃいましたらアドバイスをお願い位します
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。