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

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

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

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

Ruby on Rails

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

Q&A

解決済

1回答

2001閲覧

[Ruby on Rails]OAuth::Unauthorized 401 Unauthorizedというエラーが解消できません

akairen

総合スコア18

Ruby

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

Ruby on Rails

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

0グッド

0クリップ

投稿2020/02/10 13:23

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
を参考に設定したのですが間違っていたらすみません)

どこかおかしい点にお気づきの方がいらっしゃいましたらアドバイスをお願い位します

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

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

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

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

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

guest

回答1

0

自己解決

Callback URLsに
http://127.0.0.1:3000/auth/twitter/callback
http://localhost:3000/auth/twitter/callback
と本番環境のURLを入れたら解決できました

投稿2020/02/11 05:41

akairen

総合スコア18

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問