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

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

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

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

Ruby on Rails 6

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

Ruby on Rails

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

Q&A

解決済

1回答

1538閲覧

Rails APIモードのdevise_token_authでのCookieOverflowの解決方法

Dearg

総合スコア22

Devise

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

Ruby on Rails 6

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

Ruby on Rails

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

1グッド

0クリップ

投稿2022/05/17 07:27

編集2022/05/17 17:00

前提

Ruby On RailsをAPIモードで使用し、フロントエンドをReactを用いて、WEBアプリの開発を個人で行っています。
Railsのdeviseとdevise_token_authを使用してユーザー認証を実装しています。

以下2つの記事がReact+Rails+devise_token_authという形だったので参考にしました。
https://qiita.com/kazama1209/items/caa387bb857194759dc5
https://zenn.dev/shogo_matsumoto/articles/c6485b39c5f621

環境

Ruby On Rails : 6.1.5
devise:4.8.1
devise_token_auth:1.2.0
MySQL

問題

一通り実装が終わりサインアップから動作させていたのですが、ログインするユーザーの情報のサイズが少しでも大きいと下のようにRails側でActionDispatch::Cookies::CookieOverflowというエラーが発生してしまいます。

具体的には、
・(Postmanで)emailとpaswordのみでサインアップした場合は問題ないが、加えてnameも設定するとユーザー情報取得時にエラーが発生する
・emailとpasswordのみでサインアップしたアカウントでも、別ブラウザなどで同時に複数のアカウントでログインするとユーザー情報取得時にエラーが発生する
といった状況です。

コードとしては、localhost:3000/api/v1/auth/sessions宛に{uid, accss-token, client}をヘッダーに付けてgetリクエストを行った際に、sessions_controller.rbのcurrent_api_v1_userの部分(ユーザー情報取得時)で発生しているようです。

どこかで、格納する容量が40KBを超えるとこのようなエラーが発生すると聞きいた気がします。とはいえ、名前を設定したユーザーが1人ログインするだけでエラーが生じるのは正常ではないと思うのですが...

初歩的なミスかもしれませんが、よろしくお願いいたします。

コード

エラーコード

puma

1ActionDispatch::Cookies::CookieOverflow (ActionDispatch::Cookies::CookieOverflow): 2 3actionpack (6.1.5.1) lib/action_dispatch/middleware/cookies.rb:678:in `commit' 4actionpack (6.1.5.1) lib/action_dispatch/middleware/cookies.rb:496:in `[]=' 5actionpack (6.1.5.1) lib/action_dispatch/middleware/session/cookie_store.rb:110:in `set_cookie' 6rack (2.2.3) lib/rack/session/abstract/id.rb:403:in `commit_session' 7rack (2.2.3) lib/rack/session/abstract/id.rb:268:in `context' 8rack (2.2.3) lib/rack/session/abstract/id.rb:260:in `call' 9actionpack (6.1.5.1) lib/action_dispatch/middleware/cookies.rb:689:in `call' 10warden (1.2.9) lib/warden/manager.rb:36:in `block in call' 11warden (1.2.9) lib/warden/manager.rb:34:in `catch' 12warden (1.2.9) lib/warden/manager.rb:34:in `call' 13rack (2.2.3) lib/rack/etag.rb:27:in `call' 14rack (2.2.3) lib/rack/conditional_get.rb:27:in `call' 15rack (2.2.3) lib/rack/head.rb:12:in `call' 16activerecord (6.1.5.1) lib/active_record/migration.rb:601:in `call' 17actionpack (6.1.5.1) lib/action_dispatch/middleware/callbacks.rb:27:in `block in call' 18activesupport (6.1.5.1) lib/active_support/callbacks.rb:98:in `run_callbacks' 19actionpack (6.1.5.1) lib/action_dispatch/middleware/callbacks.rb:26:in `call' 20actionpack (6.1.5.1) lib/action_dispatch/middleware/executor.rb:14:in `call' 21actionpack (6.1.5.1) lib/action_dispatch/middleware/actionable_exceptions.rb:18:in `call' 22actionpack (6.1.5.1) lib/action_dispatch/middleware/debug_exceptions.rb:29:in `call' 23actionpack (6.1.5.1) lib/action_dispatch/middleware/show_exceptions.rb:33:in `call' 24railties (6.1.5.1) lib/rails/rack/logger.rb:37:in `call_app' 25railties (6.1.5.1) lib/rails/rack/logger.rb:26:in `block in call' 26activesupport (6.1.5.1) lib/active_support/tagged_logging.rb:99:in `block in tagged' 27activesupport (6.1.5.1) lib/active_support/tagged_logging.rb:37:in `tagged' 28activesupport (6.1.5.1) lib/active_support/tagged_logging.rb:99:in `tagged' 29railties (6.1.5.1) lib/rails/rack/logger.rb:26:in `call' 30actionpack (6.1.5.1) lib/action_dispatch/middleware/remote_ip.rb:81:in `call' 31actionpack (6.1.5.1) lib/action_dispatch/middleware/request_id.rb:26:in `call' 32rack (2.2.3) lib/rack/runtime.rb:22:in `call' 33activesupport (6.1.5.1) lib/active_support/cache/strategy/local_cache_middleware.rb:29:in `call' 34actionpack (6.1.5.1) lib/action_dispatch/middleware/executor.rb:14:in `call' 35actionpack (6.1.5.1) lib/action_dispatch/middleware/static.rb:24:in `call' 36rack (2.2.3) lib/rack/sendfile.rb:110:in `call' 37actionpack (6.1.5.1) lib/action_dispatch/middleware/host_authorization.rb:148:in `call' 38rack-cors (1.1.1) lib/rack/cors.rb:100:in `call' 39rack-cors (1.1.1) lib/rack/cors.rb:100:in `call' 40railties (6.1.5.1) lib/rails/engine.rb:539:in `call' 41puma (5.6.4) lib/puma/configuration.rb:252:in `call' 42puma (5.6.4) lib/puma/request.rb:77:in `block in handle_request' 43puma (5.6.4) lib/puma/thread_pool.rb:340:in `with_force_shutdown' 44puma (5.6.4) lib/puma/request.rb:76:in `handle_request' 45puma (5.6.4) lib/puma/server.rb:441:in `process_client' 46puma (5.6.4) lib/puma/thread_pool.rb:147:in `block in spawn_thread'

sessions_controller.rb

Ruby

1class Api::V1::Auth::SessionsController < ApplicationController 2 def index 3 if current_api_v1_user 4 render json: { is_login: true, data: current_api_v1_user } 5 else 6 render json: { is_login: false, message: "ユーザーが存在しません" } 7 end 8 end 9end

application_controller.rb

Ruby

1class ApplicationController < ActionController::API 2 include DeviseTokenAuth::Concerns::SetUserByToken 3 skip_before_action :verify_authenticity_token, raise: false 4end

devise_token_auth.rbで変更した部分

Ruby

1 config.change_headers_on_each_request = false 2config.token_lifespan = 2.weeks 3 config.headers_names = {:'access-token' => 'access-token', 4 :'client' => 'client', 5 :'expiry' => 'expiry', 6 :'uid' => 'uid', 7 :'token-type' => 'token-type' }

User.rb

Ruby

1class User < ActiveRecord::Base 2 # Include default devise modules. Others available are: 3 # :confirmable, :lockable, :timeoutable, :trackable and :omniauthable 4 devise :database_authenticatable, :registerable, 5 :recoverable, :rememberable, :validatable, :confirmable 6 include DeviseTokenAuth::Concerns::User 7end

debise_token_authによるUserのmigrationファイル

Ruby

1class DeviseTokenAuthCreateUsers < ActiveRecord::Migration[6.1] 2 def change 3 4 create_table(:users) do |t| 5 ## Required 6 t.string :provider, :null => false, :default => "email" 7 t.string :uid, :null => false, :default => "" 8 9 ## Database authenticatable 10 t.string :encrypted_password, :null => false, :default => "" 11 12 ## Recoverable 13 t.string :reset_password_token 14 t.datetime :reset_password_sent_at 15 t.boolean :allow_password_change, :default => false 16 17 ## Rememberable 18 t.datetime :remember_created_at 19 20 ## Confirmable 21 t.string :confirmation_token 22 t.datetime :confirmed_at 23 t.datetime :confirmation_sent_at 24 t.string :unconfirmed_email # Only if using reconfirmable 25 26 ## Lockable 27 # t.integer :failed_attempts, :default => 0, :null => false # Only if lock strategy is :failed_attempts 28 # t.string :unlock_token # Only if unlock strategy is :email or :both 29 # t.datetime :locked_at 30 31 ## User Info 32 t.string :name 33 # t.string :nickname 34 # t.string :image 35 t.string :email 36 t.string :admin 37 38 ## Tokens 39 t.text :tokens 40 41 t.timestamps 42 end 43 44 add_index :users, :email, unique: true 45 add_index :users, [:uid, :provider], unique: true 46 add_index :users, :reset_password_token, unique: true 47 add_index :users, :confirmation_token, unique: true 48 # add_index :users, :unlock_token, unique: true 49 end 50end
sho_a5👍を押しています

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

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

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

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

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

guest

回答1

0

自己解決

参考にした2つの記事で混ぜてはいけないコードを混ぜてしまったようです。自己解決しました。

投稿2022/06/04 13:33

Dearg

総合スコア22

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問