どうも、三町哲平です!
夜中3時にふと手動でポートフォリオのテストをしようと思い投稿機能やログイン機能などをいじり倒していたのですがその時にアカウントの新規登録をしようと思いました。
今までだと、ユーザー名/メールアドレス/パスワード/再度パスワードを入力して新規登録するボタンを押したら、認証メールが登録したメールアドレスへ送られて、そのメールのリンクをクリックすることでユーザー登録完了な訳なのですが、なぜか今回はメールが送れない...
ちなみに出先だった為、本番環境で試していたのですが、
・・・
このページは表示できません
ちなみにこのページは、500 Internal Server Errorの表示なので、Webサーバーに何らかの問題が発生した際のエラーになります。
今回は、このエラーの解決までをまとめました。
※新規登録は、下記の内容で登録
ユーザー名: test
メールアドレス: f●●●●●●@rakuten.jp
エラーを調べよう
今回発生した500 Internal Server Errorですが、あくまでこの表示は本番環境になりますので、エラー表示はデフォルトで非表示になっています。よって詳細までは分かりません。
ここで詳細を調べようと思ったら、開発環境で試してみる事が一番なのかもしれませんが、あくまで出先で本番環境しか触れない中で試せる事といったら、似たような動きをする所を手当たり次第調べていくことになりますが、今回の事象で考えられる仮説は、
- deviseのgemがおかしな挙動をしているのではないか?
- メール機能が使えなくなっているのではないか?
上記の2点が思い付いたので一つずつ仮説を試していきましょう!
1. deviseのgemがおかしな挙動をしているのではないか?
まず、deviseの挙動がおかしくないか調べてみますが、今回やったのは、
① 既に登録しているアカウントでログインしてみる
__テストユーザー__でログインできました!
② 今回、新規登録したユーザーが仮登録されているか調べる
__test(新規登録したユーザー)__が一覧に仮登録されています!
deviseは、問題無いですね。
2. メール機能が使えなくなっているのではないか?
メール機能が使えるかどうか調べるには、他にメールを使用しているところを試してみたら分かりますね。
① 新規登録したアカウントの確認メールを送ってみる
エラーが発生!
② 今回、新規登録したユーザーが仮登録されているか調べる
またしてもエラーが発生!
どうも本番環境で、メールを送れなくなっているみたいです。
開発環境で調べる
ここからは、自宅に帰って本番環境で行った対応と同じ対応をしましたが結果は、本番環境も開発環境も同じタイミングでエラーが発生しました。
しかし、本番環境と開発環境の大きな違いは、エラー内容を詳細に見れることです。
ちなみに今回のエラー内容の詳細は、
初めて見るエラーですね...。
とにかくわからないエラーに関しては、ググってみるに限るのでググってみました。
__535-5.7.8 Username and Password not accepted. Learn more at__で、検索
上記の記事がヒットしたので、記事を参考にエラー解決を試みました。
...が、エラー解決には至りませんでした。
しかし、__Username and Password not accepted__を翻訳してみると、__ユーザー名とパスワードが受け入れられません__と日本語化されます。
ユーザー名とパスワードは、絶対登録してあるし、誤字脱字もない筈なのに...と思いポートフォリオで使用していたgmailのGoogleアカウントのセキュリティから__アプリ パスワード__の項目を見てみると、
__なし__って書いているんですが...
つまりアプリ パスワードが登録していないことになっていました。
アプリ パスワードを消した心当たりが無いのに、何で消えているのかはこの時直ぐには分からなかったのですが、これしか考えられないということで、__アプリ パスワード__を再設定し直して、環境変数に追加後、開発環境でお問い合わせフォームを使用してみると、
お問い合わせいただきありがとうございました。
無事、お問い合わせ機能使用出来ていますね!
※その他、最初の本題であった新規登録や確認メールも無事復旧しました。
新規登録をしてみましょう!
⬇︎
本人確認用のメールを送信しました。メール内のリンクからアカウントを有効化させてください。
出来ましたね!
認証メールも問題無く届いていました!この後、開発環境だけではなく本番環境でも試しましたが共に正常に動くようになりました。
良かったです。
さいごに
メールは送れるようになりましたが、結局__なぜ一度登録していたはずのアプリ パスワードが消えていたのか!?__その問題は解決していませんが、これに関しては実はこの記事の既出画像の中にヒントががありました。
1週間前にGoogleアカウントのパスワードをセキュリティ対策の為、再設定していました。(この記事のエラー発生は、6月6日)
100%これが原因とまでは言い切れませんが、変化点と言えばここしかないのでほぼ100%でこれが原因と言って間違い無いでしょう。
次回、パスワード変更時に確認が必要ですね。
Googleパスワードを再設定すると、アプリ パスワードが自動的に削除される。
ひとまず解決です。