Laravel通知系统通过定义通知类统一发送邮件、数据库消息等,使用php artisan make:notification InvoicePaid生成类,via方法指定mail和database渠道,toMail设置邮件内容,toDatabase返回数据数组,用户模型调用notify发送,支持批量通知,数据库通知需执行notifications:table迁移,未读通知通过unreadNotifications获取并可标记为已读。
Laravel 的通知系统提供了一种简单、统一的方式来发送各种类型的消息,比如邮件、短信、数据库记录、Slack 消息等。你可以通过定义通知类来集中管理这些消息的发送逻辑,而无需在控制器中混杂发送代码。
使用 Artisan 命令可以快速生成一
个通知类:
这会在 app/Notifications 目录下创建 InvoicePaid.php 文件。通知类中最重要的方法是 toMail、toArray 或 toDatabase,它们定义了不同渠道下的消息格式。
以邮件和数据库为例,假设我们要在发票支付后通知用户:
class InvoicePaid extends Notificationvia 方法指定通知应通过哪些渠道发送。支持的频道包括:mail、database、slack、broadcast 等。
你可以通过模型实例上的 notify 方法发送通知。Laravel 默认在 User 模型中使用了 Notifiable trait,因此可以直接调用:
use App\Notifications\InvoicePaid;也可以批量通知多个用户:
User::all()->each->notify(new InvoicePaid);如果你只是想使用某个特定通道(例如只存数据库),可以用:
Notification::send($users, new InvoicePaid);若使用 database 通道,需先创建数据表保存通知:
php artisan notifications:table然后执行迁移:
php artisan migrate数据库中的 data 字段会存储 toDatabase 返回的数组(序列化为 JSON)。
获取未读通知:
$user->notifications;获取未读通知:
$user->unreadNotifications;标记为已读:
$user->unreadNotifications->markAsRead();基本上就这些。Laravel 的通知系统结构清晰,扩展性强,适合用于解耦业务逻辑和消息发送。只需定义一次通知类,就能轻松支持多渠道输出。不复杂但容易忽略细节,比如迁移表或正确返回数组格式。