在 laravel 控制器中不使用 sanctum 获取用户信息

问题:

在不使用 sanctum 中间件的情况下,如何在控制器中获取用户信息?该 api 需要在用户登录和未登录的状态下都可访问。

解答:

步骤 1:移除 sanctum 中间件

从路由组或控制器方法中移除 auth:sanctum 中间件。

步骤 2:在控制器中获取 auth 实例

在控制器中,使用以下代码获取 auth 实例:

$auth = illuminatesupportacadesuth::guard('sanctum');
登录后复制

步骤 3:检查用户登录状态

现在,你可以使用 $auth->check() 检查用户是否已登录。返回 true 表示已登录,false 表示未登录。

步骤 4:获取用户信息

如果用户已登录,你可以使用 $auth->user() 获取用户信息,包括 id、用户名等信息。

示例代码:

if ($auth->check()) {
    $user = $auth->user();
    // 处理已登录用户
} else {
    // 处理未登录用户
}
登录后复制

注意:

使用此方法可以获取是否已登录的信息以及用户信息。但它不会执行任何验证,因此在处理用户信息时仍需要根据需要进行额外验证。

以上就是Laravel控制器如何绕过Sanctum中间件获取用户信息?的详细内容,更多请关注慧达安全导航其它相关文章!

点赞(0)

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部