Laravel 5.5:授权策略AccessDeniedHttpException此操作未经授权

时间:2018-12-03 07:49:27

标签: php laravel policy

我创建了授权策略,因此遇到了这个问题。

我已经看到了这些解决方案,但是我的问题尚未解决:

Solution 1

Solution 2

Solution 3

以下是代码:

ArticalesController类中使用的函数:

public function show(Articale $articale)
{
    $this->authorize('view', $articale);
    return view('articales.show',compact('articale'));
}

ArticalePolicy类:

        <?php

        namespace App\Policies;

        use App\User;
        use App\Articale;
        use Illuminate\Auth\Access\HandlesAuthorization;

        class ArticalePolicy
        {
            use HandlesAuthorization;

            /**
             * Determine whether the user can view the articale.
             *
             * @param  \App\User  $user
             * @param  \App\Articale  $articale
             * @return mixed
             */
            public function view(User $user, Articale $articale)
            {
                return $user->id == $articale->user_id;
            }

AuthServiceProvider类:     

namespace App\Providers;
use Illuminate\Support\Facades\Gate;
use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider;
class AuthServiceProvider extends ServiceProvider
{
    /**
     * The policy mappings for the application.
     *
     * @var array
     */
    protected $policies = [
        'App\Model' => 'App\Policies\ModelPolicy',
        Articale::class => ArticalePolicy::class,
    ];

    /**
     * Register any authentication / authorization services.
     *
     * @return void
     */
    public function boot()
    {
        $this->registerPolicies();

        //
    }
}

1 个答案:

答案 0 :(得分:4)

尝试使用这样的型号名称,将其替换为AuthServiceProvider

替换

Articale::class => ArticalePolicy::class,

'App\Articale' => 'App\Policies\ArticalePolicy',