0

0

Laravel怎么实现API认证_Laravel Sanctum轻量级认证方案【源码】

冰火之心

冰火之心

发布时间:2026-02-04 15:15:08

|

265人浏览过

|

来源于php中文网

原创

Sanctum 是 Laravel 9+ 中适用于 SPA 和移动 App 的轻量级 API 认证方案,基于数据库 token 与 Cookie 自动管理实现「登录即认证」,比 Passport 更简单安全;需正确配置 stateful 域名、CSRF 流程、跨域策略及中间件使用。

laravel怎么实现api认证_laravel sanctum轻量级认证方案【源码】

Sanctum 适合单页应用(SPA)和移动 App 的轻量级 API 认证,它不依赖 OAuth2 复杂流程,而是靠数据库 token + Cookie 自动管理实现「登录即认证」。如果你用的是 Laravel 9+ 且项目不需要多平台统一授权中心,直接上 Sanctum 比 Passport 更省心、更安全、更少 bug。

安装 Sanctum 并发布配置

执行命令安装包并发布配置文件和迁移:

composer require laravel/sanctum
php artisan vendor:publish --provider="Laravel\Sanctum\SanctumServiceProvider"

这会生成 config/sanctum.php 和数据库迁移文件。迁移前确认你的 users 表有 id 主键且类型为整型(UUID 用户需额外处理)。

  • 迁移前务必运行 php artisan migrate,否则调用 createToken() 会报 SQLSTATE[42S02]: Base table or view not found
  • sanctum.php 中的 stateful 配置决定哪些域名走 Session + Cookie 认证(如 ['localhost', '127.0.0.1']),开发环境必须包含前端地址,否则跨域请求无法携带 session
  • 生产环境记得把 SESSION_DOMAIN 设为根域名(如 .example.com),否则子域名间 Cookie 不共享

在 API 路由中启用 Sanctum 中间件

Sanctum 提供两个核心中间件:auth:sanctum(校验登录态)和 throttle:api(限流)。它们必须配合 api 路由组使用,但注意:Laravel 默认 api 组不启用 session,所以不能直接用 auth:sanctum —— 必须显式加 middleware('auth:sanctum') 到具体路由或组里。

正确写法示例(routes/api.php):

use Illuminate\Http\Request;

Route::middleware('auth:sanctum')->group(function () {
    Route::get('/user', function (Request $request) {
        return $request->user();
    });
});
  • 不要在 api 路由中混用 web 中间件(如 webencrypt_cookies),会导致 CSRF token 错误或 session 初始化失败
  • 移动端调用时,token 必须放在 Authorization: Bearer {token} 请求头;SPA 浏览器调用则靠 Cookie 自动携带,无需手动传 token
  • 如果返回 401 Unauthenticated 但用户已登录,大概率是前端没发 X-XSRF-TOKEN 或后端没配好 stateful 域名

生成与校验 Token 的典型用法

Sanctum 的 token 是模型关联的,每个 token 对应一个 PersonalAccessToken 实例,保存在数据库中。用户登录后,调用 createToken() 创建 token,并把 token 字符串($token->plainTextToken)返回给前端存储。

示例登录逻辑(AuthController@login):

if (Auth::attempt($credentials)) {
    $user = Auth::user();
    $token = $user->createToken('api-token');
    return response()->json([
        'user' => $user,
        'token' => $token->plainTextToken,
    ]);
}
  • createToken() 第二个参数可传权限数组(如 ['read', 'write:posts']),后续可用 $user->tokenCan('write:posts') 校验
  • token 删除要调用 $user->currentAccessToken()->delete()(登出当前设备)或 $user->tokens()->delete()(登出所有设备)
  • 不要把 $token->accessToken 当作字符串返回——它是加密后的值,实际要用 $token->plainTextToken

CSRF 保护与跨域请求的坑

SPA 调用 Sanctum API 时,首次请求需先 GET /sanctum/csrf-cookie 获取 CSRF token,并将其放入后续请求的 X-XSRF-TOKEN 头中。这个接口必须走 web 中间件,且不能被 api 组包裹。

正确配置(routes/web.php):

Route::get('/sanctum/csrf-cookie', function () {
    return response()->noContent(204);
})->middleware('web');
  • 前端 Axios 示例中,需开启 withCredentials: true,否则 Cookie 不发送;同时服务端响应头要有 Access-Control-Allow-Credentials: true,且 Access-Control-Allow-Origin 不能为 *(必须指定具体域名)
  • Laravel 10+ 默认禁用 SameSite=None,若前后端跨协议(HTTP ↔ HTTPS)或跨二级域,需在 config/session.php 中设置 'same_site' => 'none' 并确保启用 HTTPS
  • Chrome 91+ 对第三方 Cookie 更严格,本地开发用 localhost 通常没问题,但用 127.0.0.1 可能触发 SameSite 限制,建议统一用 localhost

Sanctum 看似简单,但 Cookie 生命周期、CSRF 流程、跨域策略、token 权限粒度这些点一旦配错,错误信息非常模糊。最常卡住的地方不是代码写法,而是环境配置和前端请求头是否对齐 —— 建议用浏览器开发者工具 Network 面板逐个检查 Cookie、XSRF-TOKEN、Authorization 头是否存在、是否被拦截。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

322

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

281

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

456

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

375

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

106

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

72

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

68

2025.08.05

什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

179

2024.05.11

抖音网页版入口与视频观看指南 抖音官网视频在线访问
抖音网页版入口与视频观看指南 抖音官网视频在线访问

本专题汇总了抖音网页版的入口链接、官方登录页面以及视频观看入口,帮助用户快速访问抖音网页版,提供免登录访问方式和直接进入视频播放页面的方法,确保顺利浏览和观看抖音视频。

19

2026.02.04

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 11万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

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

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