0

0

Laravel中怎么实现表单令牌_Laravel @csrf指令用法【总结】

穿越時空

穿越時空

发布时间:2026-02-27 10:50:03

|

481人浏览过

|

来源于php中文网

原创

laravel表单必须包含@csrf指令以输出隐藏令牌字段,否则触发419错误;该机制由verifycsrftoken中间件强制执行,依赖有效session,且仅适用于web路由组。

laravel中怎么实现表单令牌_laravel @csrf指令用法【总结】

Laravel 表单必须带 CSRF 令牌,否则提交会直接返回 419 Page Expired 错误 —— 这不是配置问题,是框架默认强制保护机制。

为什么 @csrf 不是可选项

Laravel 默认启用中间件 VerifyCsrfToken,它会拦截所有非 GET/HEAD/OPTIONS 请求,并比对请求中携带的 _token 值与 session 中存储的令牌是否一致。没传、传错、过期,都会被拒绝。

  • @csrf 本质是输出一个隐藏字段:<input type="hidden" name="_token" value="xxx">
  • 它依赖当前用户 session 已启动(即已执行 session_start() 或经过 StartSession 中间件)
  • 在 API 路由中默认不启用 CSRF 验证(因为无 session),所以 @csrfapi 中间件组下无效且没必要

@csrf 必须放在表单内部,且不能重复

多个 @csrf 指令不会报错,但只取第一个生效;如果写在 <form></form> 外面,浏览器不会把它作为表单数据提交,后端收不到 _token,必然 419。

  • ✅ 正确写法:
    <form method="POST" action="/users"><br>  @csrf<br>  <input name="name"><br></form>
  • ❌ 错误写法:
    <div>@csrf</div><form>...</form>
    <form>@method('PUT') @csrf @csrf</form>
  • 注意:@method@csrf 是独立指令,顺序无关,但都必须在 <form></form> 标签内

手动插入 _token 的场景和风险

某些情况(比如 JS 动态提交、AJAX)无法用 @csrf,需手动提取令牌值。常见做法是从 meta 标签读取:

提客AI提词器
提客AI提词器

「直播、录课」智能AI提词,搭配抖音直播伴侣、腾讯会议、钉钉、飞书、录课等软件等任意软件。

下载
<meta name="csrf-token" content="{{ csrf_token() }}">

然后在 JS 中设置请求头:

  • AJAX 全局设置(推荐):
    $.ajaxSetup({<br>  headers: { 'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content') }<br>});
  • 单独请求时传 header 或 data:data: { _token: $('meta[name="csrf-token"]').attr('content') }
  • ⚠️ 风险:不要把 csrf_token() 直接塞进 URL 查询参数(如 ?_token=xxx),容易被日志、代理、Referer 泄露
  • ⚠️ 注意:该 meta 标签必须出现在页面 中,且不能被 JS 删除或覆盖

令牌失效的典型原因和排查点

即使写了 @csrf,仍出现 419,大概率不是指令问题,而是环境或流程异常:

  • 用户 session 过期或未生成(例如未登录却访问需要 session 的表单页)
  • 浏览器禁用了 Cookie,导致 session_id 无法持久化
  • 使用了无状态中间件(如 api 组)但错误地启用了 VerifyCsrfToken
  • 服务器时间偏差过大(Laravel 令牌含时间戳,验证时容忍窗口默认 120 分钟,但严重偏差仍可能触发)
  • 负载均衡下 session 未共享,导致 token 生成和验证落在不同机器上

最快速验证方式:打开开发者工具 → Network → 看表单提交的 Request Payload 是否含 _token 字段,再比对页面源码中 @csrf 输出的 value 是否与 session 中一致(可通过 dd(session('_token')) 查看)。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

335

2024.04.09

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

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

289

2024.04.09

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

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

645

2024.04.09

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

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

382

2024.04.10

laravel入门教程
laravel入门教程

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

131

2025.08.05

laravel实战教程
laravel实战教程

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

81

2025.08.05

laravel面试题
laravel面试题

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

71

2025.08.05

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

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

181

2024.05.11

html5播放器怎么用
html5播放器怎么用

本合集全面介绍HTML5播放器的使用方法,涵盖基础语法、自定义控制、兼容性处理及实战示例。阅读专题下面的文章了解更多详细内容。

0

2026.02.27

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Laravel---API接口
Laravel---API接口

共7课时 | 0.6万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.7万人学习

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

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