Laravel5.3~5.5 使用默认api验证登陆

讲解如何使用laravel5.3~5.5框架默认的api验证登陆。

讲道理

config/auth.php里,默认guard有web和api

'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users',
    ],

    'api' => [
        'driver' => 'token',
        'provider' => 'users',
    ],
],

框架自带有2个guard,在Illuminate\Auth\AuthManager里定义的。此类有2个方法:

public function createSessionDriver($name, $config) {...}
public function createTokenDriver($name, $config) {...}

分别调用SessionGuard和TokenGuard,由resolve($name)方法来调用。

配置文件中的driver填token,既是使用 Illuminate\Auth\TokenGuard,打开此文件,可以看到默认的token验证字段名是api_token

public function __construct(UserProvider $provider, Request $request)
{
    $this->request = $request;
    $this->provider = $provider;
    $this->inputKey = 'api_token';
    $this->storageKey = 'api_token';
}
开始

数据库中添加字段不重复字段:api_token

$table->string('api_token', 60)->unique();

登陆验证:
验证了用户名和密码之后,生成一个api_token,填到数据库里。然后就可以使用token来访问需要登陆的页面了。
使用Auth门面调用guard,使用validate()方法验证身份:(返回bool)

Auth::guard('api')->validate(['api_token' => $request->api_token)]); 
// 这里必须是$request->api_token,否则可以验证,单获取不到用户信息

user()方法返回用户信息

Auth::guard('api')->user();

等等,具体查看Illuminate\Auth\TokenGuard类。
测试的话,直接使用get请求就行了:

http://xxx.com/user?api_token=xxxxxxxxxx

原文地址:http://www.fullstack.pub/doc/16

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值