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