Lumen 5.2 用户认证详细介绍

1、简介

Lumen中的认证和Laravel使用同样的底层库,但和完整的Laravel框架相比配置完全不一样。由于Lumen不再支持Session状态,如果你想要认证输入的请求,只能通过API token的方式实现。

2、起步

认证服务提供者

注:在使用Lumen的认证特性之前,需要取消bootstrap/app.php文件中注册服务提供者AuthServiceProvider前面的注释。
app/Providers目录下的AuthServiceProvider只包含单个调用Auth::viaRequest,viaRequest方法接收一个输入请求需要被认证时调用的闭包。在这个闭包中,你可以解析需要的App\User实例,如果通过请求参数找不到对应的认证用户,该闭包会返回null:

$this->app['auth']->viaRequest('api', function ($request) {
    // Return User or null...
});

再次重申,你可以解析任何你需要的认证用户。你可以使用请求头中的API token获取请求参数来获取对应用户。

访问认证用户

和完整的Laravel框架一样,你可以使用Auth::user()方法获取当前用户。此外,你还可以使用Illuminate\Http\Request实例上的$request->user()方法:

use Illuminate\Http\Request;

$app->get('/post/{id}', ['middleware' => 'auth', function (Request $request, $id) {
    $user = Auth::user();
    $user = $request->user();
    //
}]);

注:如果你想要使用Auth::user()来访问当前认证用户,需要取消bootstrap/app.php中$app->routeMiddleware()前面的注释。

当然,需要认证的路由要分配auth中间件,因此,也要取消bootstrap/app.php文件中$app->routeMiddleware()前面的注释:

$app->routeMiddleware([
    'auth' => App\Http\Middleware\Authenticate::class,
]);

时间: 2024-09-29 02:41:37

Lumen 5.2 用户认证详细介绍的相关文章

CITRIX ICA协议用户认证详细过程?

问题描述 求大神解决疑问CITRIXICA协议用户认证详细过程?ICA协议详细字段含义?会话传输数据压缩方式? 解决方案 解决方案二:同求解决方案三:一样的---

关于opensips用户认证配置文件 opensips.cfg 使用介绍_Linux

opensips用户认证配置文件-opensips.cfg opensips.cfg配置文件,红色标记的为添加修改的部分,亲自测试! ## $Id: opensips.cfg 9742 2013-02-05 10:24:48Z vladut-paiu $## OpenSIPS residential configuration script#     by OpenSIPS Solutions <team@opensips-solutions.com>## This script was ge

新浪微博怎么认证V用户 新浪微博橙V认证技巧介绍

手机新浪微博怎么认证橙V? 一.首先打开新浪微博,点击账号设置点V认证申请: 二.满足五点要求就可以,1.头像清晰:2.绑定手机:3.关注数大于30:4.粉丝数超过100:5.2个互粉橙V好友: 三.完成以上要求之后,点击上传材料证明: 四.上传在职证明,等待审核就可以,让两名带V朋友帮你转发信息就可以了: 五.申请基本在3-5天内就可以显示橙V认证图标了. 以上就是新浪微博橙V认证技巧介绍,赶紧来认证起来,尊享橙V特权吧!

分享十款最出色的PHP安全开发库中文详细介绍

  1. PHP入侵检测系统 开发库中文详细介绍-芭提雅6996详细介绍"> PHP IDS(即PHP-入侵检测系统)是一套易于使用.结构良好.速度出色且专门面向PHP类Web应用程序的先进安全层.这套入侵检测系统既不提供任何缓和及杀毒机制,也不会对恶意输入内容进行过滤,其作用单纯为识别出攻击者们针对站点进行的恶意活动.并以大家需要的方式作出及时提醒.凭借着一整套经过实践检验及相当严格的过滤规则,该检测系统会针对任何攻击活动给出一个影响评级数值,从而帮助用户更轻松地了解应如何应对当前出现的

mongodb的用户认证

MongoDB:用户认证          MongoDB 安装后默认不启用认证,也就是说在本地可以通过 mongo 命令不输入用户名密码, 直接登陆到数据库,下面介绍下启用 mongodb 用户认证,详细如下:        启用 mongodb 认证只需要在启动 mongod 服务时配置 auth 参数成 'true'即可可 ,在配置 参数前先添加超级用户.  一 启用认证 --1.1 增加管理用户  > use admin; switched to db admin > db.addUs

small标签详细介绍

html教程,small标签详细介绍. 类似于<em></em>之类的短语元素,既可以改进文档结构,同时也保留了预期的视觉样式.但<small></small>在平时应用中不是很常见,第一眼的影响是淘宝UED是不是在这个小问题上疏忽了? 关于<small></small>,网上搜索下来的结果也很零碎,有的说不建议使用,也有的在废弃标签里没有提到它的名字.好在<精通HTML 语义.标准和样式>一书中对此作了详细的解释. &l

微博1分钱变5000元活动网址内容规则详细介绍

  新浪微博开启了"1分钱变5000元现金"活动,用于推广微博支付.在活动期间内(4月25日-5月5日),只要用户通过微博支付成功支付1分钱,变会100%获得现金礼包,金额从1元到5000元不等.下面小编为大家详细介绍微博1分钱变5000元活动详细内容. 活动时间:2014年4月25日-5月5日 参与方式:使用微博支付成功支付一分钱,即可100%获得微博支付的现金奖励,金额最低1元,最高5000元 无论是否绑定过支付宝都可以参与该活动,未绑定的需要绑定.获得的奖金将在7个工作日内打到对

十款最出色的PHP安全开发库中文详细介绍(1)

1. PHP入侵检测系统 开发库中文详细介绍(1)-webapp详细开发介绍"> PHP IDS(即PHP-入侵检测系统)是一套易于使用.结构良好.速度出色且专门面向PHP类Web应用程序的先进安全层.这套入侵检测系统既不提供任何缓和及杀毒机制,也不会对恶意输入内容进行过滤,其作用单纯为识别出攻击者们针对站点进行的恶意活动.并以大家需要的方式作出及时提醒.凭借着一整套经过实践检验及相当严格的过滤规则,该检测系统会针对任何攻击活动给出一个影响评级数值,从而帮助用户更轻松地了解应如何应对当前出

为Qmail增加smtp用户认证功能

本文介绍如何让 qmail 增加 smtpd-auth 功能. 软件需求 系统版本:RedHat6.2 必需软件:1.qmail-1.03 (www.qmail.org) qmail的主要程序包 2.checkpassword (cr.yp.to/checkpwd.html) 让qmail使用系统用户认证的密码认证包或vpopmail (www.inter7.com/vpopmail) 让qmail支持mysql和虚拟主机用户认证的密码验证包 3.qmail-smtpd.c (www.nimh.