laravel8实现用passport实现接口的登录和jwt生成(生成token)

这篇博客详细介绍了如何在Laravel应用中使用Passport插件进行API认证。首先通过Composer安装Passport,然后执行迁移创建所需数据表。接着,配置客户端授权码并修改模型及auth设置。在服务提供者中设定令牌有效期,并解决了接口登录时的认证问题。最后,演示了登录接口的实现以及测试过程中如何携带和验证token。
摘要由CSDN通过智能技术生成

1.安装passport插件

composer require laravel/passport

2.执迁迁移文件,生成数据表,保存token数据 (会直接生成5张表)

php artisan migrate

3.生成客户端授权码,必须的操作,没有会报错找不到配置文件

php artisan passport:install

 4.修改接口账号模型

use Laravel\Passport\HasApiTokens;

 5.修改config/auth.php文件中的api配置

 6.令牌的有效期,在app/Proivders/AuthServiceProvide.php文件中的boot方法添加有效期

use Laravel\Passport\Passport; 
// token认证有效期2小时 
Passport::tokensExpireIn(now()‐>addHour(2));
// 刷新token认证有效期30天 
Passport::refreshTokensExpireIn(now()‐>addDays(30));

 7.解决auth在接口中登录没有attempt问题

 

 8.验证账号

public function login(Request $request)
    {
        $validator=\Validator::make($request->all(),[
            'username'=>'required',
            'password'=>'required',
        ]);
        if ($validator->fails()){
            return ['code'=>500,'msg'=>$validator->errors()->first()];
        }

        //dd(get_class_methods(auth()));
        //应为基于auth登录,所匹配的字段不能出现中文
        $bool=auth()->guard('apiss')->attempt($request->all());
        if ($bool){
            $user=auth()->guard('apiss')->user();
            //在这里生成token
            $token=$user->createToken('api')->accessToken;
            $data=['token'=>$token,'expire'=>7200];
            return ['code'=>200,'msg'=>'登录成功','data'=>$data];
        }
        return ['code'=>500,'msg'=>'账号密码错误'];
    }

9.在hearder中加入token  

 key=Authorization

value=Bearer xxx此处为tokenxxxxxxxxx 

千万记得Bearer 后面是有一个空格的 千万记得Bearer 后面是有一个空格的 千万记得Bearer 后面是有一个空格的

10.测试中间件拦截功能

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值