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

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

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

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

Ruby on Rails

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

解決済

[Rails]deviseで"confirmation_token"が一致しているのに、メールリンクからアカウントの有効化ができない。

hajsu00
hajsu00

総合スコア118

Devise

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

Ruby on Rails

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

1回答

0評価

0クリップ

228閲覧

投稿2022/05/31 22:09

編集2022/06/01 14:09

ユーザー認証にdeviseを採用しているRailsアプリのメール送信サービスをMailgunからAWS SESに変更したところ、送られてきたメールのリンクからアカウントの有効化ができないという問題に遭遇しています。

ご助言いただけると幸いです。

開発環境

  • ruby 3.0.1
  • Rails 6.1.4.4
  • docker 20.10.12
  • docker-compos 1.29.2

前提事項

  • メールの送信にはAWS SESを使用
  • Mailgunを使用していたときには正常に認証ができていた

起きている問題

アカウント登録時の認証メール内有効化リンクをクリックしても、アカウントが有効になりません。

アカウント新規登録画面からメールアドレス等の必要事項を入力して「認証メールを送信」ボタンを押すと正常にメールが送られて来ます。しかし、メール内のurlをクリックすると「アカウント有効化リンクの再送信」ページに飛んでしまい、当該ユーザーでのログインにも失敗します(「認証が必要です」とメッセージが出ます)。

# Railsログ(抜粋) [1mUser Create (0.8ms) INSERT INTO `users` (`name`, `email`, `encrypted_password`, `confirmation_token`, `confirmation_sent_at`, `created_at`, `updated_at`) VALUES ('t_kyab', 'example@gmail.com', '$2a$12$Aak*********************************cHPoO7KKwq', 'wMB***************r1sA', '2022-05-31 21:32:41', '2022-05-31 21:32:41.975876', '2022-05-31 21:32:41.975876') # メール内urlの内容 https://myapp.com/users/confirmation?confirmation_token=wMB***************r1sA
root@515826d65af1:/var/www/hangartalk# rails c Warning: the running version of Bundler (2.2.15) is older than the version that created the lockfile (2.3.4). We suggest you to upgrade to the version that created the lockfile by running `gem install bundler:2.3.4`. Running via Spring preloader in process 830 Loading development environment (Rails 6.1.6) [1] pry(main)> User.find_by(email: 'hajsu00@gmail.com') User Load (1.1ms) SELECT `users`.* FROM `users` WHERE `users`.`email` = 'hajsu00@gmail.com' LIMIT 1 => #<User id: 51, name: "t_kyab", admin: false, introduction: "", location: "", email: "hajsu00@gmail.com", created_at: "2022-06-01 06:32:41.975876000 +0900", updated_at: "2022-06-01 06:32:41.975876000 +0900">

ログ全文

bash

Started POST "/users" for 172.19.0.1 at 2022-05-31 21:32:41 +0000  (0.9ms) SELECT `schema_migrations`.`version` FROM `schema_migrations` ORDER BY `schema_migrations`.`version` ASC Processing by Users::RegistrationsController#create as HTML Parameters: {"authenticity_token"=>"[FILTERED]", "user"=>{"name"=>"t_kyab", "email"=>"example@gmail.com", "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "commit"=>"認証メールを送信する"} TRANSACTION (0.6ms) BEGIN User Exists? (0.9ms) SELECT 1 AS one FROM `users` WHERE `users`.`email` = BINARY 'example@gmail.com' LIMIT 1 User Create (0.8ms) INSERT INTO `users` (`name`, `email`, `encrypted_password`, `confirmation_token`, `confirmation_sent_at`, `created_at`, `updated_at`) VALUES ('t_kyab', 'example@gmail.com', '$2a$12$Aak*********************************cHPoO7KKwq', 'wMB***************r1sA', '2022-05-31 21:32:41', '2022-05-31 21:32:41.975876', '2022-05-31 21:32:41.975876') TRANSACTION (4.1ms) COMMIT Rendering users/mailer/confirmation_instructions.html.erb Rendered users/mailer/confirmation_instructions.html.erb (Duration: 3.6ms | Allocations: 947) Devise::Mailer#confirmation_instructions: processed outbound mail in 392.9ms [Aws::SES::Client 200 0.452997 0 retries] send_raw_email(raw_message:{data:#<String "Date: Tue, 31 May 2022 21:32:42 +0000\r\nFrom: My App Talk <info@myapp.com>\r\nReply-To: My App <info@myapp.com>\r\nTo: example@gmail.com\r\nMessage-ID: <6296897a603b2_17698c6823e@515826d65af1.mail>\r\nSubject: =?UTF-8?Q?=E3=83=A1=E3=83=BC=E3=83=AB=E3=82=A2=E3=83=89=E3=83=AC=E3=82=B9=E7=A2=BA=E8=AA=8D=E3=83=A1=E3=83=BC=E3=83=AB?=\r\nMime-Version: 1.0\r\nContent-Type: text/html;\r\n charset=UTF-8\r\nContent-Transfer-Encoding: base64\r\n\r\nPHA+aGFqc3UwMEBnbWFpbC5jb20g44GV44KTPC9wPg0KDQo8cD7ku6XkuIvj\r\nga7jg6rjg7Pjgq/jgpLjgq/jg6rjg4Pjgq/jgZfjgabjgIHjg6Hjg7zjg6vj\r\ngqLjg4njg6zjgrnjga7oqo3oqLzjgpLlrozkuobjgZfjgabjgY/jgaDjgZXj\r\ngYTjgII8L3A+DQoNCjxwPjxhIGhyZWY9Imh0dHBzOi8vaGFuZ2FydGFsay1h\r\ncHAuY29tL3VzZXJzL2NvbmZpcm1hdGlvbj9jb25maXJtYXRpb25fdG9rZW49\r\nd01CR1lLelRHaGVFTmZaLXIxc0EiPuODoeODvOODq+OCouODieODrOOCueOC\r\nkuiqjeiovOOBmeOCizwvYT48L3A+DQoNCjxwPuKAu+acieWKueacn+mZkOOB\r\nr+acrOODoeODvOODq+OBrueZuuihjOOBi+OCie+8ku+8lOaZgumWk+S7peWG\r\nheOBp+OBmeOAgjwvcD4NCjxwPuKAu+OBk+OBruODoeODvOODq+OBr+mAgeS/" ... (1396 bytes)>},destinations:["example@gmail.com"]) Delivered mail 6296897a603b2_17698c6823e@515826d65af1.mail (461.6ms) Date: Tue, 31 May 2022 21:32:42 +0000 From: My App <info@myapp.com> Reply-To: My App<info@myapp.com> To: example@gmail.com Message-ID: <6296897a603b2_17698c6823e@515826d65af1.mail> Subject: =?UTF-8?Q?=E3=83=A1=E3=83=BC=E3=83=AB=E3=82=A2=E3=83=89=E3=83=AC=E3=82=B9=E7=A2=BA=E8=AA=8D=E3=83=A1=E3=83=BC=E3=83=AB?= Mime-Version: 1.0 Content-Type: text/html; charset=UTF-8 Content-Transfer-Encoding: base64 PHA+aGFqc3UwMEBnbWFpbC5jb20g44GV44KTPC9wPg0KDQo8cD7ku6XkuIvj ga7jg6rjg7Pjgq/jgpLjgq/jg6rjg4Pjgq/jgZfjgabjgIHjg6Hjg7zjg6vj gqLjg4njg6zjgrnjga7oqo3oqLzjgpLlrozkuobjgZfjgabjgY/jgaDjgZXj gYTjgII8L3A+DQoNCjxwPjxhIGhyZWY9Imh0dHBzOi8vaGFuZ2FydGFsay1h cHAuY29tL3VzZXJzL2NvbmZpcm1hdGlvbj9jb25maXJtYXRpb25fdG9rZW49 d01CR1lLelRHaGVFTmZaLXIxc0EiPuODoeODvOODq+OCouODieODrOOCueOC (省略) PHA+LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS08L3A+IA0K Redirected to http://localhost/users/sign_in Completed 302 Found in 1219ms (ActiveRecord: 10.8ms | Allocations: 503206) Started GET "/users/sign_in" for 172.19.0.1 at 2022-05-31 21:32:42 +0000 Processing by Users::SessionsController#new as HTML Rendering layout layouts/application.html.erb Rendering users/sessions/new.html.erb within layouts/application Rendered /usr/local/bundle/gems/devise-i18n-1.10.2/app/views/devise/shared/_error_messages.html.erb (Duration: 0.1ms | Allocations: 13) Rendered users/sessions/new.html.erb within layouts/application (Duration: 7.9ms | Allocations: 2054) [Webpacker] Everything's up-to-date. Nothing to do Rendered layouts/_shim.html.erb (Duration: 0.1ms | Allocations: 7) Rendered layouts/_header.html.erb (Duration: 10.4ms | Allocations: 782) Rendered layouts/_message.html.erb (Duration: 2.4ms | Allocations: 138) Rendered layouts/_notification.html.erb (Duration: 6.8ms | Allocations: 579) Rendered layouts/_footer.html.erb (Duration: 6.7ms | Allocations: 372) Rendered layout layouts/application.html.erb (Duration: 168.2ms | Allocations: 13821) Completed 200 OK in 176ms (Views: 174.1ms | ActiveRecord: 0.0ms | Allocations: 16344)

関連コード

ruby

# myapp/app/controllers/users/registrations_controller.rb ... # POST /resource def create super user = User.find_by(email: params[:user][:email]) if !user.nil? user.avatar.attach(io: File.open(Rails.root.join('app/assets/images/default_avatar.png')), filename: 'default_avatar.png') user.user_cover.attach(io: File.open(Rails.root.join('app/assets/images/default_cover.png')), filename: 'default_cover.png') user.create_glider_initial_log!(at_present: Date.today, total_time: 0, total_number: 0, pic_winch_time: 0, (省略) number_of_stall_recovery: 0) end end ...

ruby

# myapp/app/mailers/application_mailer.rb class ApplicationMailer < ActionMailer::Base default from: 'Myapp <info@myapp.com>' layout 'mailer' end

html.erb

# myapp/app/views/users/mailer/confirmation_instructions.html.erb <p><%= @resource.email %> さん</p> <p>以下のリンクをクリックして、メールアドレスの認証を完了してください。</p> <p><%= link_to 'メールアドレスを認証する', confirmation_url(@resource, confirmation_token: @token) %></p> <p>※有効期限は本メールの発行から24時間以内です。</p> <p>※このメールは送信専用です。ご返信をいただいてもご連絡できかねますのでご了承ください。<br></p>

ruby

# myapp/config/environments/development.rb config.action_mailer.raise_delivery_errors = false config.action_mailer.default_url_options = { host: 'myapp.com', protocol: 'https' } config.action_mailer.delivery_method = :ses config.action_mailer.perform_caching = false

確認したこと

$ rails cで、データベースに保存された情報を確認しました

##### 今回ユーザー認証に失敗したユーザー 1] pry(main)> User.find_by(email: 'example@gmail.com') User Load (1.1ms) SELECT `users`.* FROM `users` WHERE `users`.`email` = 'example@gmail.com' LIMIT 1 => #<User id: 51, name: "t_kyab", admin: false, introduction: "", location: "", email: "hajsu00@gmail.com", created_at: "2022-06-01 06:32:41.975876000 +0900", updated_at: "2022-06-01 06:32:41.975876000 +0900">
'seed'で保存した、認証済みのユーザー
[2] pry(main)> User.find(1) User Load (1.4ms) SELECT `users`.* FROM `users` WHERE `users`.`id` = 1 LIMIT 1 => #<User id: 1, name: "Example User", admin: true, introduction: "ここはユーザーのプロフィール文です。入力可能な文字数は160字にする予定です。ここはユーザーのプロフ...", location: "東京", email: "example@railstutorial.org", created_at: "2022-06-01 06:31:01.286221000 +0900", updated_at: "2022-06-01 06:31:01.469712000 +0900">

もしかしてconfirmation_tokenは発行はされているが、データベースに保存されていない?
そうだとしても以前のメールサービスでは正常に動いていた点が気になります。

"devise-i18n-views"がインストールされていないことを確認

以下の記事を参考に、devise-i18n-viewsがgemfileに存在しないことを確認し、bundle updatebundle cleanを実行しましたが、症状は改善しませんでした。

https://ja.stackoverflow.com/questions/70434/devise-%E3%83%91%E3%82%B9%E3%83%AF%E3%83%BC%E3%83%89%E3%83%AA%E3%82%BB%E3%83%83%E3%83%88%E5%87%A6%E7%90%86%E3%81%A7-%E7%94%9F%E6%88%90%E3%81%97%E3%81%9F%E3%83%88%E3%83%BC%E3%82%AF%E3%83%B3%E3%81%A8%E3%83%AA%E3%82%BB%E3%83%83%E3%83%88%E6%A1%88%E5%86%85%E3%83%A1%E3%83%BC%E3%83%AB%E3%81%AB%E5%B1%8A%E3%81%8F%E3%83%88%E3%83%BC%E3%82%AF%E3%83%B3%E3%81%8C%E4%B8%80%E8%87%B4%E3%81%97%E3%81%AA%E3%81%84


お力を貸していただけると幸いです。

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Devise

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

Ruby on Rails

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。