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

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.测试中间件拦截功能