使用 Laravel Notifynder 扩展轻松实现 Laravel 应用的消息通知功能

Laravel Notifications

1、简介

Notifynder 以简单的方式提供了强大的消息通知管理功能:其提供的完整API可用于对消息通知的各种处理,比如存储、检索以及组织处理成百上千条通知的代码库。有了Notifynder,你可以在几分钟内在你的Laravel项目中“启用”消息通知功能。

目前支持的数据库包括MySQL、Postgres和SQLite。

2、安装

使用Composer安装该扩展:

composer require fenos/notifynder

然后到config/app.php中注册服务提供者:

Fenos\Notifynder\NotifynderServiceProvider::class,

以及门面:

'Notifynder' => Fenos\Notifynder\Facades\Notifynder::class,

发布该扩展包的配置文件到config目录:

php artisan vendor:publish --provider="Fenos\Notifynder\NotifynderServiceProvider"

最后运行数据库迁移生成相应数据表:

php artisan migrate

3、快速上手

创建分类

在开始使用Notifynder之前,我们需要简单了解“分类”这一术语在Notifynder中的职责,分类是消息通知的主体,通过唯一的名称来区分,并且拥有对应的通知文本,每个通知都要绑定到一个分类上,以便于管理和维护。

首先我们使用Notifynder提供的Artisan命令来创建一个分类 :

php artisan notifynder:create:category "user.following" "{from.username} started to follow you"

这会在数据库notification_categories表中创建一条新纪录:

notification_categories

功能实现

接下来确定要被通知的模型,通常我们选择User模型,这个被选择的模型类要使用 Notifable Trait:

use Fenos\Notifynder\Notifable;

class User extends Model{
    use Notifable;
}

这样我们的模型实体就可以处理消息通知了:

$user = User::find(1);

$user->getNotifications($limit = null, $paginate = null, $order = 'desc');
$user->getNotificationsNotRead($limit = null, $paginate = null, $order = 'desc');
$user->getLastNotification();
$user->countNotificationsNotRead($category = null);
$user->readAllNotifications();

注:如果你不想使用 Notifable Trait,也可以直接使用Notifynder门面上的对应方法。

4、发送通知

发送通知非常简单:

$from_user_id = 1;
$to_user_id = 2;

Notifynder::category('user.following')
            ->from($from_user_id)
            ->to($to_user_id)
            ->url('http://laravelacademy.org/notifications')
            ->send();

发送通知后我们来检索通知:

$userNotified = User::find($to_user_id);
dd($userNotified->getNotificationsNotRead());

还可以一次发送多个通知,这里我们给多个用户发送通知:

// It send a notification to all the users
try {
    $this->notifynder->loop($users, function(NotifynderBuilder $builder, $user) {

       $builder->category('sayhello')
           ->from(1)
           ->to($user->id)
           ->url('http://localhost')
           ->extra(compact('period_day'));

    })->send();
} catch (EntityNotIterableException $e) {
} catch (IterableIsEmptyException $e) {
}

更多使用可参考官方文档:https://github.com/fenos/Notifynder/wiki

学院君 has written 982 articles

Laravel学院院长,终身学习者

积分:113047 等级:P12 职业:手艺人 城市:杭州

19 条回复

  1. lizi lizi says:
    in the v4 is No Artisan command - Database changes belongs to migrations and seeds, there you can add your category. v4已经不支持artisan.请安装v3版本
  2. denny denny says:
    这个解决了吗?我也遇到了这个问题
  3. zz zz says:
    我是按找这样来的,使用使用Notifynder提供的Artisan命令来创建一个分类 为什么会提示 There are no commands defined in the "notifynder:create" namespace. 怎么解决呢?
  4. 小珑 小珑 says:
    @ HEBE6_启程 <?phpnamespace AppProviders;use IlluminateSupportFacadesConfig;class PusherWrapper{ protected $pusher; public function __construct() { $app_id = Config::get('335');//pusher.appId $app_key = Config::get('1be309d81d21201');//pusher.appKey $app_secret = Config::get('af1b2732ab4a8b');//pusher.appSecret $this->pusher = new Pusher($app_key, $app_secret, $app_id); } public function __call($name, $args) { return call_user_func_array(array($this->pusher, $name), $args); }}怎么回事,报错啊。FatalThrowableError in PusherWrapper.php line 17: Class 'Pusher' not found
  5. 小珑 小珑 says:
    laravel massage好,为什么没说明呢
  6. 佘奕楷 佘奕楷 says:
    @ 学院君 对呀,notifications_categories_in_groups 和notification_groups 这两张表是讲关于分组功能的,但是我也找不到文档,到头来还是不知道这两张表有啥作用以及之间的关系
  7. 麦索@PMcaff 麦索@PMcaff says:
    @ HEBE6_启程 请问如何在读取的时候获取特定分组下的消息,找官方的文档没找到
  8. zex zex says:
    想问下可以跨数据库使用吗?比如公司后台收到一个认证请求,运营人员在后台通过后,发送一个通知给用户,后台和公司网站的产品分属不同的project

登录后才能进行评论,立即登录?