laravel接口开发JWTAuth

本文详细介绍了如何在 Laravel 框架中安装和配置 JWTAuth,包括通过 Composer 安装、配置文件发布、加密密钥生成、用户模型更新、注册 Facade、修改 auth.php 配置等步骤。此外,还讲解了 JWTToken 的创建、获取、检查、解析、删除、刷新和使用方法,以及处理 JWTAuth 调用异常的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、安装配置

1、使用composer安装

composer require tymon/jwt-auth 1.*@rc

2、配置

 2.1发布配置文件

# 这条命令会在 config 下增加一个 jwt.php 的配置文件
php artisan vendor:publish --provider="Tymon\JWTAuth\Providers\LaravelServiceProvider"

 2.2 生成加密密钥

# 这条命令会在 .env 文件下生成一个加密密钥,如:JWT_SECRET=foobar
php artisan jwt:secret

 2.3 更新用户模型

use Tymon\JWTAuth\Contracts\JWTSubject;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;

class User extends Authenticatable implements JWTSubject
{

    use Notifiable;
    
    public function getJWTIdentifier()
    {
        return $this->getKey();
    }

    public function getJWTCustomClaims()
    {
        return [];
    }
    
}

 2.4 注册两个Facade(config/app.php)

'aliases' => [
        ...
        // 添加以下两行
        'JWTAuth' => 'Tymon\JWTAuth\Facades\JWTAuth',
        'JWTFactory' => 'Tymon\JWTAuth\Facades\JWTFactory',
],

 辅助函数auth()、Facade类JWTAuth

 2.5 修改auth.php

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

    'api' => [
        'driver' => 'jwt',        // 原来是 token 改成jwt
        'provider' => 'users',
    ],
],

二、JWTToken详解

token创建、获取、检验、解析、删除(获取)、刷新、使用

创建:基于账号密码、模型、模型id、辅助函数

$id = 1;
$arr = ['username'=>'admin','username'=>'admin'];

1、JWTAuth
JWTAuth::attempt($arr);

2、fromUser or fromSubject
JWTAuth::fromUser($user);

3、auth()
    1、auth()->login($user);
    2、auth()->tokenById($id);

获取

1、JWTAuth
JWTAuth::parseToken();
JWTAuth::parseToken()->getToken();
JWTAuth::getToken();

2、Auth
auth()->getToken();

检验(合法性、有效性)

1、JWTAuth
JWTAuth::setToken($token);
JWTAuth::setToken($token)->check();
JWTAuth::parseToken()->check();

2、auth()
auth('api')->check()

解析

1、JWTAuth
JWTAuth::parseToken();
JWTAuth::parseToken()->toUser();
JWTAuth::parseToken()->authenticate(); // only、attr

2、auth()
auth()->user() // only、attr
auth()::parseToken()->toUser();

删除

1、JWTAuth
JWTAuth::parseToken()->invalidate(); 

2、auth()
auth()->logout();

刷新

1、JWTAuth
JWTAuth::parseToken()->refresh();

使用

1、url:?token=你的token

2、header 中,建议用这种,因为在 https 情况下更安全:Authorization:Bearer 你的token

 

三、JWTAuth调用异常

php artisan key:generate
php artisan jwt:secret
php artisan config:clear
php artisan config:cache

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值