我已经阅读了Laravel文档以了解自定义身份验证。我研究了Guard身份验证:
保护自定义 您还可以自定义用于验证和注册用户的“防护”。首先,在LoginController,RegisterController和ResetPasswordController上定义一个guard方法。该方法应返回一个保护实例:
use Illuminate\Support\Facades\Auth;
protected function guard()
{
return Auth::guard('guard-name');
}
以上部分来自Laravel文档。我开发了CRUD操作项目,此操作应仅由管理员级别用户完成。为此,我认为后卫定制将是更好的选择。在上面的例子中,“守卫名字”在这里是什么?它是具有管理级权限的用户的名称吗?
还有一种情况是管理员可以将管理员的权限分配给其他用户。由于缺乏Laravel文档中的详细说明,我无法弄清楚如何使用guard来解决上述情况。什么可以是更好的选择?
答案 0 :(得分:0)
guard-name
是您的自定义警卫的名称。还有一个关于如何添加自己的后卫(https://laravel.com/docs/5.6/authentication#adding-custom-guards)的完整示例。
Guards可以定义不同的身份验证方法(例如基于会话或令牌)。对我来说,这听起来像是在寻找Laravel的大门和政策。有了这些,您可以针对给定资源授权用户。 https://laravel.com/docs/5.6/authorization
使用策略时,您可以定义过滤器。此过滤器将在策略上的任何其他方法之前调用。因此,使用before
过滤器,您可以检查用户是否为管理员。
public function before($user, $ability)
{
if ($user->isSuperAdmin()) {
return true;
}
}