如何防止Laravel中的中间件发生动作

时间:2018-01-05 21:07:19

标签: php laravel middleware

我有以下路线:

Route::get('post/{postId}/deleteComment/{commentId}', [
    'uses' => 'CommentController@getDeleteComment',
    'as' => 'content.post.deleteComment'
])->middleware('checkDeleteComment');

以及以下中间件:

namespace App\Http\Middleware;

use App\Comment;
use Closure;
use Auth;

class checkDeleteComment
{
    public function handle($request, Closure $next)
    {
       $id = $request->route()->parameter('commentId');

       $comment = Comment::where('id', $id)->first();

        if (! Auth::user()->id == $comment->user_id) {
            return redirect()->back();
        } else {
            return $next($request);
        }
    }
}

中间件位于我的App/Http/Kernel.php中,如下所示:

protected $routeMiddleware = [
        'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
        'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
        'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
        'can' => \Illuminate\Auth\Middleware\Authorize::class,
        'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
        'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
        'checkAdmin' => \App\Http\Middleware\checkAdmin::class,
        'checkDeleteComment' => \App\Http\Middleware\checkDeleteComment::class,
    ];

然而,当我尝试删除与给定链接不同的评论时,我总是成功。有人能帮助我吗?

1 个答案:

答案 0 :(得分:1)

而不是说is notis not equal

if (Auth::user()->id != $comment->user_id) {
相关问题