首页 > 解决方案 > Laravel 'can' 中间件返回错误 500 “此操作未经授权”

问题描述

我正在尝试创建一个基于 laravel 框架的网站。我陷入了策略的权限控制中。这是我的代码: + 政策注册App\Providers\AuthServiceProvider

class AuthServiceProvider extends ServiceProvider
{
    protected $policies = [
        User::class => UserPolicy::class,
        Category::class => CategoryPolicy::class
    ];

    public function boot()
    {
        $this->registerPolicies();

        try {
            Permission::all()->each(function($permission) {
                Gate::define($permission->name, function ($user) use($permission) {
                    return $user->hasPermission($permission->name);
                });
            });
        } catch (\Exception $e) {
            Log::notice('Unable to register gates. Either no database connection or no permissions table exists.');
        }
    }
}
class UserPolicy
{
    use HandlesAuthorization;

    public function viewAny(User $user)
    {
        return true;
    }

    public function view(User $user, User $target_user)
    {
        return $user->id === $target_user->id;
    }

}
Route::get('/users', 'Api\UserController@getUsers')->middleware('can:view-users');
Route::get('/users/{user_id}', 'Api\UserController@getUser')->middleware('can:view-users');
Route::put('/users/{user_id}', 'Api\UserController@updateUser')->middleware('can:edit-users');
    public function getUsers(UserRequest $request) {
        $users = $this->userRepository->getAll();
        $this->authorize('view', $user);
        return response($users, 200);
    }

    public function getUser(UserRequest $request, $user_id) {
        $user = $this->userRepository->find($user_id);
        $this->authorize('view', $user);
        return response($user, 200);
    }
{
    "error": "This action is unauthorized."
}

代码行:

$this->gate->authorize($ability, $this->getGateArguments($request, $models));handle()上面的函数中抛出错误。

谁能指出我的错误?

标签: phplaravelmiddleware

解决方案


解决了。经过数小时阅读库中的源代码后,我发现了问题。我在没有模块的情况下为我的应用程序使用api了警卫。因此,类passport中的变量无法设置为经过身份验证的用户并获得值。为了解决这个问题,我创建了自己的中间件而不是 laravel 中间件并用于获取经过身份验证的用户。$userResolverIlluminate\Auth\Access\GatenullAuthorizeAuthorizeAuth::guard('api')->user()


推荐阅读