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

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

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

Deviseとは、Ruby-on-Railsの認証機能を追加するプラグインです。

Ruby on Rails

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

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

0回答

1123閲覧

【Rails/React】axios経由でdeviseで認証するとcurrent_userがnilになる

Hinoarashi.

総合スコア76

Devise

Deviseとは、Ruby-on-Railsの認証機能を追加するプラグインです。

Ruby on Rails

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

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2022/03/03 15:20

以下私が使ってる環境です。

  • Rails
  • React.js
  • axios
  • devise
  • devise-token-auth
  • js-cookie

http:localhost:3000/admin/auth/sign_inにpostリクエストを行なって、ログインまで行うことができましたが、current_userを打つとnilになります。
namespaceを切ってるので、一応current_admin_admin_userも打ってみましたがnilになりました。

リクエストを行なったフロントは以下の通りです。

export function AdminPageBase(params: adminUserData & UserListProps) { const classes = useStyles(); const uid = Cookies.get("_uid"); const access_token = Cookies.get("_access_token"); const client = Cookies.get("_client"); useEffect(() => { axios .post(`${process.env.REACT_APP_ENDPOINT}/admin/sessions`, { headers: { accsess_token: access_token ?? "", uid: uid!, client: client!, }, }) .then((response) => { Cookies.set("_access_token", response.headers["access-token"]); Cookies.set("_client", response.headers["client"]); Cookies.set("_uid", response.headers["uid"]); }) .catch(() => {}); }, []); ...

上記を実行するとnilになるのですが、コントローラをpryで止めてparamsを打つと
#<ActionController::Parameters {"headers"=>{"accsess_token"=>"2hUxLpyMD9Dux8_6WP3BbA", "uid"=>"sample@yahoo.co.jp", "client"=>"CCqv2ZsyOQlaPfsAmCVmLA"}, "controller"=>"admin/sessions", "action"=>"index", "session"=>{"headers"=>{"accsess_token"=>"2hUxLpyMD9Dux8_6WP3BbA", "uid"=>"sample@yahoo.co.jp", "client"=>"CCqv2ZsyOQlaPfsAmCVmLA"}}} permitted: false>
のようにaccess_tokenなどは入ってます。

確かにDBにuidは入ってるので、current_userがよしなににやってくれると思ったのですが、そうでもないみたいです。

何の設定が間違ってるのでしょうか?
すいませんが、お助けいただけると非常に助かります。

sessions_controller.rb

class Admin::SessionsController < ApplicationController def index binding.pry end helper_method :current_user, :user_signed_in? end

routes.rb

namespace :admin do mount_devise_token_auth_for 'AdminUser', at: 'auth', controllers: { registrations: 'admin/auth/registrations', } post '/sessions', to: 'sessions#index' end

admin_user

devise :database_authenticatable, :registerable, :recoverable, :rememberable, :trackable, :validatable include DeviseTokenAuth::Concerns::User

devise_token_auth

config.headers_names = { 'access-token': 'access-token', 'client': 'client', 'expiry': 'expiry', 'uid': 'uid', 'token-type': 'token-type', }

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問