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

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

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

Q&A

解決済

1回答

615閲覧

laravel8でメール送信処理を共通化したい

ttpk

総合スコア338

0グッド

0クリップ

投稿2022/08/17 15:22

前提

laravelでwebアプリを開発しています

実現したいこと

  • 定期実行している自動ツイート機能が完了したらメールを送れるようにしたい

発生している問題・エラーメッセージ

Trying to get property 'name' of non-object {"exception":"[object] (ErrorException(code: 0): Trying to get property 'name' of non-object

該当のソースコード

App\Console\Commands配下にtwitterへの予約投稿実行機能のクラスを作成し
そこでメール送信用のコントローラーを呼び出しています

php

1 $mail = app()->make('App\Http\Controllers\SendMailController'); 2 $mail->sendMailExec();

メール送信用のコントローラーは以下になります

PHP

1<?php 2 3namespace App\Http\Controllers; 4 5use Illuminate\Http\Request; 6use App\Mail\SendMail; 7use Illuminate\Support\Facades\Mail; 8use App\Mail\MailNotify; 9use Illuminate\Support\Facades\Auth; 10 11class SendMailController extends Controller 12{ 13 public function index(){ 14     $mail_name = Auth::user()->name; 15 $mail_title = "自動ツイート完了"; 16 $mail_text = $mail_name. "様 自動ツイート処理が完了しました。"; 17 $mail_to = Auth::user()->email; 18 Mail::to($mail_to)->send( new SendMail($mail_title,$mail_text) ); 19 20 } 21} 22

エラーの内容から、メール送信用のコントローラーがlaravelの認証チェックに入っておらず
Authのデータが取れていないことが原因であることまでは推測できています

web.phpへ認証を行うグループ内にルーティングを追加しましたが
エラーは変わっていません

PHP

1Route::group(['middleware' => 'check'],function(){ 2 Route::get('/sendMailExec', [App\Http\Controllers\SendMailController::class, 'index'])->name('sendMailExec'); 3});

ルーティングの書き方、コントローラの呼び出し方のどちらかが問題だと思うのですが
確認するべき点はどこになるでしょうか?

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

Laravel v8.83.23
PHP v7.4.18

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

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

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

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

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

guest

回答1

0

ベストアンサー

コントローラーをこんな使い方することは絶対にない。ここから間違ってる。

$mail = app()->make('App\Http\Controllers\SendMailController');

Auth::user()はブラウザから見た時にしか機能しない。
コマンドを実行した時には「ログインユーザー」なんてどこにもいない。
特定のユーザー情報を使いたいなら

php

1$user = User::find(1); 2$mail_title = "自動ツイート完了"; 3$mail_text = $user->name . "様 自動ツイート処理が完了しました。"; 4Mail::to($user)->send(new SendMail($mail_title, $mail_text));

これをコントローラーではなくコマンドに書く。

投稿2022/08/18 01:31

kawax

総合スコア10377

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

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

ttpk

2022/08/18 03:38

回答ありがとうございます。 コマンドでデータベースからユーザー情報を取るようにしたところ メールを送信できるようになりました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問