php - 如何停止向自己发送通知?

标签 php mysql laravel laravel-5 laravel-5.3

当我喜欢自己的帖子时,我会收到通知,这不应该发生,

现在我想要的是,如果像我自己的帖子一样,通知不应保存在数据库中,

我的 Controller :

    public function store(Request $request,$id)
    {
    $like = new Like();
    $like->user_id =Auth::user()->id;
    $like->post_id = $id;
    if($like->save())
    {
        if (Auth::user()->id != $id)
        {
            $user = User::findOrFail($request->get('user_id'));
            Notification::send($user , new likePost($like));
            $data = auth()->user()->name.'Liked Your Post '.'<Strong>'.$request->input('title').'</strong'.'<\br>'.'On'.Carbon::now();
            StreamLabFacades::pushMessage('test' , 'likePost' , $data);
        }
    }

最佳答案

您的第二个参数 ($id) 指的是帖子 ID。

您的意思是,如果您的 post_id 不等于您的 user_id,则发送通知。在这种情况下,只会出现一种情况。

我不确定你的逻辑是如何设置的,但我想你有另一个名为 Post 的模型。

你的逻辑应该是这样的:

public function store(Request $request, $post_id){

    $like = Like::create([ 'user_id' => Auth::user()->id, 'post_id' => $post_id]);

    $post = Post::whereId($post_id)->first();

    if( $post->user_id !== Auth::user()->id ) {
        //SEND Notification code here
    }

}

更好的方法是在 Like 模型中创建一个指向 Post 模型的关系。参见这里:https://laravel.com/docs/5.4/eloquent-relationships#one-to-many-inverse

特别是一对多逆。他们有一个带有注释的示例,我认为与您的案例非常相似。

希望这有帮助

关于php - 如何停止向自己发送通知?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43957466/

相关文章:

php - 几天后如何将数据从一个表移动到另一个表

PHP按键值降序对数组进行数字排序

php - 使用 PHP 访问 MySQL DB 行数据

php - 无法将图像数据写入路径。干预图像 Laravel 5.2

php - 如何使用 Laravel Mix Setup 将 Laravel 数据传递到 Vue 根实例

php - 如何在不使用 ajax 重新加载的情况下提交我的表单?

带有 sleep() 的 PHP 脚本不会在连接关闭时退出

java.net.ConnectException : Connection refused: connect openshift

mysql - 如何在时间范围内按分钟分组并在 MySQL 中显示 0 值?

php - 使用两个连接加入 laravel