0

0

一文介绍Laravel中Token的实现机制

PHPz

PHPz

发布时间:2023-04-23 09:13:14

|

2569人浏览过

|

来源于php中文网

原创

laravel是一个使用php编程语言开发的web应用框架,它的卓越表现得益于其内部集成大量功能强大的扩展包。其中就包括了token的底层实现。token,即令牌,是web应用程序常用的一种身份验证方式,通常用于保护api和web服务免受非法访问。在这篇文章中,我们将介绍laravel中token的实现机制。

一、令牌的概念

Token,顾名思义,就是指一种令牌,是一种标记,可以代表某种身份信息或者授权信息。它通常由服务器产生并发放给客户端,客户端收到令牌后将其存放在本地,在后续请求时加入请求头或者请求参数中,作为身份验证或授权的标识。服务器通过检查令牌是否有效,就可以确定请求是否具有身份验证或者授权信息。

令牌的使用能够更有效地保护Web应用免受未经授权的访问,尤其是在API和Web服务中,令牌是必不可少的。

二、 Laravel Token的实现

Laravel作为一款优秀的Web应用框架,在其内置的Auth功能中提供了Token的支持。在Laravel中,Token的实现使用了Laravel Sanctum这个扩展包。

2.1 Laravel Sanctum

Laravel Sanctum是一款轻量级的身份验证包,可以为Laravel应用程序提供API身份验证,基于API秘钥或者Token,让应用程序更好的运行在无状态环境中,如SPA应用程序、单页应用程序和移动应用程序等。Laravel Sanctum提供了以下功能:

  1. 无需配置即可开始使用;
  2. 支持使用session、Token以及API秘钥等多种身份验证方式;
  3. 内置了多种身份验证的实现,如cookie、Token、auth等;
  4. 提供了方便的身份验证和Token生成;
  5. 更好的自定义身份验证流程。

2.2 Token的实现原理

在Laravel Sanctum中,Token的实现原理与session实现原理类似。在请求中,客户端向服务器发出请求时,将Token作为请求参数或Header中的Authorization字段发送给服务器。服务器在检查Token是否有效,并在有效期内,给予请求操作的权限或者返回错误信息。Token的实现流程如下:

  1. 创建Token:当用户登录时,Sanctum将为该用户生成一个随机的Token,并将该Token保存在后台数据库中;
  2. 发送Token:将Token作为请求参数或者Header中的Authorization字段发送给服务器;
  3. Token验证:在服务器端,Sanctum将检查接收到的Token是否有效,并决定授权或拒绝;
  4. Tokens管理:Sanctum提供了一系列API来创建、撤销、查找和验证Token。

三、 Laravel Token的使用

Sanctum提供了方便易用的API来使用Token,包括Token的创建、撤销、查找和验证等。下面是Token的使用方式:

3.1 安装 Sanctum

在应用程序中,首先需要将Sanctum的依赖包引入到应用的composer.json文件:

composer require laravel/sanctum

安装完成后,需要在config/app.php文件中添加如下配置:

'providers' => [ 
    // Other service providers... 
    Laravel\Sanctum\SanctumServiceProvider::class, 
],

3.2 发布配置

在安装完成后,需要运行以下命令来发布Sanctum的配置文件:

LOVESTUdio多校园网络店铺
LOVESTUdio多校园网络店铺

主要更新介绍: 完美整合Discuz!论坛,实现一站式登陆、退出、注册; 同步所有会员资料; 新增购物车功能,商品购买更加方便、快捷; 新增部分快捷菜单,网站访问更加方便; 限制首页商品、店铺标题显示长度; 修正会员后台管理不能更改密码的错误; 完善商品显示页面所有功能链接; 修正后台标签管理部分错误; 修正前台学校列表不按后台顺序显示的错误; 修正搜索功能中学校名称过长导致显示紊乱的现象; 修正

下载
php artisan vendor:publish --provider="Laravel\Sanctum\SanctumServiceProvider"

3.3 配置Middleware

在使用Sanctum时,需要在对应的路由中添加中间件。在Laravel中,已经内置了API认证的中间件,可以直接调用。

3.4 创建Token

在登录后,可以使用如下代码来为当前用户创建Token:

use Illuminate\Http\Request; 
use Illuminate\Support\Facades\Hash; 
use Illuminate\Validation\ValidationException; 
use App\Models\User; 
use Illuminate\Support\Facades\Auth; 
use Illuminate\Support\Facades\Route; 

// 创建Token 
Route::post('/api/token/create', function (Request $request) { 
    $request->validate([ 
        'email' => 'required|email', 
        'password' => 'required', 
    ]); 

    $user = User::where('email', $request->email)->first(); 

    if (! $user || ! Hash::check($request->password, $user->password)) { 
        throw ValidationException::withMessages([ 
            'email' => ['The provided credentials are incorrect.'], 
        ]); 
    } 

    return $user->createToken($request->header('User-Agent'))->plainTextToken; 
});

在上面的代码中,可以看到在创建Token时,使用机器的User-Agent作为额外的参数。这里的User-Agent是一个HTTP头,记录了浏览器或应用程序的相关信息。这个信息将作为Token的一部分,使得Token一旦被盗用或者恶意使用,可以很容易地发现和撤销。

3.5 撤销Token

创建的Token一旦被盗用或者失效,可以使用如下代码撤销:

Auth::user()->tokens()->delete();

3.6 验证扩展

Sanctum还提供了良好的验证扩展,可以方便地进行访问控制,代码如下:

use Illuminate\Http\Request; 
use Illuminate\Support\Facades\Hash; 
use Illuminate\Validation\ValidationException; 
use App\Models\User; 
use Illuminate\Support\Facades\Auth; 
use Illuminate\Support\Facades\Route; 
use Laravel\Sanctum\HasApiTokens;

class User extends Authenticatable 
{
    use HasApiTokens, Notifiable;
}

使用上述代码之后,我们就可以在User模型中使用can接口来进行访问控制,代码如下:

$request->user()->can('update', $post);

在上面的代码中,can将根据当前用户的角色、权限和策略,判断用户是否有权进行更新操作。需要注意的是,用户需要正确实现自己的访问控制逻辑。

四、 总结

在本文中,我们介绍了Laravel中Token的底层实现机制,尤其是使用Sanctum扩展包的方式。Sanctum提供了方便易用的API,能够快速集成到应用程序中,并提高应用程序的安全性。Token的使用方式、创建、撤销和管理,以及访问控制等方面均进行了详细的讲解。

在今天的互联网世界中,随着API和Web服务的广泛应用,Token作为一种身份验证方式,将在很多应用程序中得到更加广泛的应用。Laravel框架提供了良好的Token实现机制,可以更好地保护Web应用免受非法访问。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2909

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1736

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1567

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1120

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1566

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1277

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1669

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1310

2023.11.13

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

31

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号