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

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

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

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

Ruby on Rails

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

AWS(Amazon Web Services)

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

Q&A

解決済

1回答

800閲覧

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

hajsu00

総合スコア151

Devise

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

Ruby on Rails

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

AWS(Amazon Web Services)

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

0グッド

0クリップ

投稿2022/05/31 22:09

編集2023/04/08 10:37

ユーザー認証に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 ('***', '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: '***') User Load (1.1ms) SELECT `users`.* FROM `users` WHERE `users`.`email` = '***@gmail.com' LIMIT 1 => #<User id: 51, name: "***", admin: false, introduction: "", location: "", email: "***@gmail.com", created_at: "2022-06-01 06:32:41.975876000 +0900", updated_at: "2022-06-01 06:32:41.975876000 +0900">

ログ全文

bash

1Started POST "/users" for 172.19.0.1 at 2022-05-31 21:32:41 +0000 2  (0.9ms) SELECT `schema_migrations`.`version` FROM `schema_migrations` ORDER BY `schema_migrations`.`version` ASC 3Processing by Users::RegistrationsController#create as HTML 4 Parameters: {"authenticity_token"=>"[FILTERED]", "user"=>{"name"=>"***", "email"=>"example@gmail.com", "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "commit"=>"認証メールを送信する"} 5 TRANSACTION (0.6ms) BEGIN 6 User Exists? (0.9ms) SELECT 1 AS one FROM `users` WHERE `users`.`email` = BINARY 'example@gmail.com' LIMIT 1 7 User Create (0.8ms) INSERT INTO `users` (`name`, `email`, `encrypted_password`, `confirmation_token`, `confirmation_sent_at`, `created_at`, `updated_at`) VALUES ('***', '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') 8 TRANSACTION (4.1ms) COMMIT 9 Rendering users/mailer/confirmation_instructions.html.erb 10 Rendered users/mailer/confirmation_instructions.html.erb (Duration: 3.6ms | Allocations: 947) 11Devise::Mailer#confirmation_instructions: processed outbound mail in 392.9ms 12[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"]) 13 14Delivered mail 6296897a603b2_17698c6823e@515826d65af1.mail (461.6ms) 15Date: Tue, 31 May 2022 21:32:42 +0000 16From: My App <info@myapp.com> 17Reply-To: My App<info@myapp.com> 18To: example@gmail.com 19Message-ID: <6296897a603b2_17698c6823e@515826d65af1.mail> 20Subject: =?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?= 21Mime-Version: 1.0 22Content-Type: text/html; 23 charset=UTF-8 24Content-Transfer-Encoding: base64 25 26PHA+aGFqc3UwMEBnbWFpbC5jb20g44GV44KTPC9wPg0KDQo8cD7ku6XkuIvj 27ga7jg6rjg7Pjgq/jgpLjgq/jg6rjg4Pjgq/jgZfjgabjgIHjg6Hjg7zjg6vj 28gqLjg4njg6zjgrnjga7oqo3oqLzjgpLlrozkuobjgZfjgabjgY/jgaDjgZXj 29gYTjgII8L3A+DQoNCjxwPjxhIGhyZWY9Imh0dHBzOi8vaGFuZ2FydGFsay1h 30cHAuY29tL3VzZXJzL2NvbmZpcm1hdGlvbj9jb25maXJtYXRpb25fdG9rZW49 31d01CR1lLelRHaGVFTmZaLXIxc0EiPuODoeODvOODq+OCouODieODrOOCueOC 32(省略) 33PHA+LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t 34LS0tLS0tLS08L3A+IA0K 35 36Redirected to http://localhost/users/sign_in 37Completed 302 Found in 1219ms (ActiveRecord: 10.8ms | Allocations: 503206) 38 39 40Started GET "/users/sign_in" for 172.19.0.1 at 2022-05-31 21:32:42 +0000 41Processing by Users::SessionsController#new as HTML 42 Rendering layout layouts/application.html.erb 43 Rendering users/sessions/new.html.erb within layouts/application 44 Rendered /usr/local/bundle/gems/devise-i18n-1.10.2/app/views/devise/shared/_error_messages.html.erb (Duration: 0.1ms | Allocations: 13) 45 Rendered users/sessions/new.html.erb within layouts/application (Duration: 7.9ms | Allocations: 2054) 46[Webpacker] Everything's up-to-date. Nothing to do 47 Rendered layouts/_shim.html.erb (Duration: 0.1ms | Allocations: 7) 48 Rendered layouts/_header.html.erb (Duration: 10.4ms | Allocations: 782) 49 Rendered layouts/_message.html.erb (Duration: 2.4ms | Allocations: 138) 50 Rendered layouts/_notification.html.erb (Duration: 6.8ms | Allocations: 579) 51 Rendered layouts/_footer.html.erb (Duration: 6.7ms | Allocations: 372) 52 Rendered layout layouts/application.html.erb (Duration: 168.2ms | Allocations: 13821) 53Completed 200 OK in 176ms (Views: 174.1ms | ActiveRecord: 0.0ms | Allocations: 16344)

関連コード

ruby

1# myapp/app/controllers/users/registrations_controller.rb 2 3... 4 # POST /resource 5 def create 6 super 7 user = User.find_by(email: params[:user][:email]) 8 if !user.nil? 9 user.avatar.attach(io: File.open(Rails.root.join('app/assets/images/default_avatar.png')), filename: 'default_avatar.png') 10 user.user_cover.attach(io: File.open(Rails.root.join('app/assets/images/default_cover.png')), filename: 'default_cover.png') 11 user.create_glider_initial_log!(at_present: Date.today, 12 total_time: 0, 13 total_number: 0, 14 pic_winch_time: 0, 15(省略) 16 number_of_stall_recovery: 0) 17 end 18 end 19...

ruby

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

html.erb

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

ruby

1# myapp/config/environments/development.rb 2 config.action_mailer.raise_delivery_errors = false 3 config.action_mailer.default_url_options = { host: 'myapp.com', protocol: 'https' } 4 config.action_mailer.delivery_method = :ses 5 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: "***", admin: false, introduction: "", location: "", email: "***@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


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

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

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

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

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

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

guest

回答1

0

自己解決

development環境なのに、hostの指定をmyapp.comとしているのが原因のようです。

投稿2022/06/01 05:09

hajsu00

総合スコア151

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問