- Laravel 教程
- Laravel - 主页
- Laravel - 概述
- Laravel - 安装
- Laravel - 应用程序结构
- Laravel - 配置
- Laravel - 路由
- Laravel - 中间件
- Laravel - 命名空间
- Laravel - 控制器
- Laravel - 请求
- Laravel-Cookie
- Laravel - 响应
- Laravel - 视图
- Laravel - 刀片模板
- Laravel - 重定向
- Laravel - 使用数据库
- Laravel - 错误和日志记录
- Laravel - 表单
- Laravel - 本地化
- Laravel - 会话
- Laravel - 验证
- Laravel - 文件上传
- Laravel - 发送电子邮件
- Laravel - AJAX
- Laravel - 错误处理
- Laravel - 事件处理
- Laravel - 外观
- Laravel - 合约
- Laravel - CSRF 保护
- Laravel - 身份验证
- Laravel - 授权
- Laravel - Artisan 控制台
- Laravel - 加密
- Laravel - 哈希
- 了解发布流程
- Laravel - 访客用户门
- Laravel - Artisan 命令
- Laravel - 分页自定义
- Laravel - 转储服务器
- Laravel - 操作 URL
- Laravel 有用资源
- Laravel - 快速指南
- Laravel - 有用的资源
- Laravel - 讨论
Laravel - 访客用户门
访客用户门功能是 2018 年 9 月发布的最新 5.7 版本的附加功能。此功能用于启动特定用户的授权过程。
在 Laravel 5.6 中,有一个过程用于为未经身份验证的用户返回false 。在 Laravel 5.7 中,我们可以通过在指定控制器中使用特定的可空类型提示来允许来宾进行授权检查,如下所示 -
<?php Gate::define('view-post', function (?User $user) { // Guests });
守则解释
通过使用可为 null 的类型提示,当来宾用户传递到 Gate 时,$user 变量将为 null。然后您可以做出有关授权该操作的决定。如果您允许可为 null 的类型并返回 true,则访客将拥有授权。如果您不使用可空类型提示,客人将自动获得 Laravel 5.7 的 403 响应,如下所示 -
403 和 404 错误之间的区别在于,当用户尝试访问未知资源或 URL 时会显示 404,而如果未经授权的用户访问网站,则会显示上面快照中提到的 403 错误。