0

0

Laravel Session::put 正确用法与基于会话的请求限流实现

花韻仙語

花韻仙語

发布时间:2025-10-20 09:50:39

|

748人浏览过

|

来源于php中文网

原创

Laravel Session::put 正确用法与基于会话的请求限流实现

本文探讨了laravel 5.8中session::put方法在实现请求限流时遇到的常见问题,指出其正确用法需指定键值对,并展示了如何结合时间戳实现基于会话的2小时请求间隔限制。通过理解session::put和session::get的工作原理,开发者可以有效地控制用户表单提交频率,避免重复操作,提升应用健壮性。

问题分析:Session::put 未按预期工作

在Laravel框架中,开发者经常需要利用会话(Session)来存储临时数据或控制用户行为,例如限制用户在一定时间内重复提交表单。然而,一个常见的误解是 Session::put('key') 这样的调用足以将一个键设置为已存在。在原始问题中,用户尝试通过 Session::put('request_has_been_sent') 来标记请求已发送,并期望通过 Session::has('request_has_been_sent') 来检查。但实际上,这种不带值的 put 调用并不会如预期般工作,导致会话键未被正确设置,从而无法实现预期的限流效果。

Session::put 的正确用法

Laravel的 Session::put() 方法设计用于存储一个键值对。这意味着,当你想要在会话中存储一个数据时,你必须同时提供键(key)和值(value)。如果只提供键而不提供值,会话系统可能不会将其视为一个有效的已设置项。

基本语法:

Session::put('key', 'value');

其中:

  • key:你想要存储在会话中的数据的名称。
  • value:与该键关联的数据。可以是字符串、数字、数组或对象。

示例:存储一个简单的标记

要正确地标记一个请求已发送,你应该为其指定一个值,例如一个布尔值 true 或一个字符串 'yes'。

// 正确设置会话
Session::put('request_has_been_sent', 'yes');

获取会话数据:

小微助手
小微助手

微信推出的一款专注于提升桌面效率的助手型AI工具

下载

要从会话中检索数据,可以使用 Session::get() 方法,同样需要提供键。

// 获取会话数据
$status = Session::get('request_has_been_sent'); // $status 将是 'yes' 或 null

检查会话键是否存在:

如果你只是想检查一个会话键是否存在,而不关心它的具体值,可以使用 Session::has() 方法。

// 检查会话键是否存在
if (Session::has('request_has_been_sent')) {
    // 会话键 'request_has_been_sent' 存在
}

实现基于会话的请求限流

为了实现文章开头提到的2小时提交限制,我们不能仅仅依赖一个简单的标记,还需要结合时间戳。以下是修正后的控制器逻辑,它将正确地利用会话来限制用户在2小时内再次提交请求:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\Session;
use App\Models\WithdrawWallet; // 假设你的模型是这个

class WithdrawController extends Controller
{
    public function submitWithdrawRequest(Request $request)
    {
        $sessionKey = 'last_withdraw_request_time';
        $limitDuration = 2 * 60 * 60; // 2小时转换为秒

        // 检查会话中是否存在上次请求的时间戳
        if (Session::has($sessionKey)) {
            $lastRequestTime = Session::get($sessionKey);
            $currentTime = now()->timestamp; // 获取当前时间戳

            // 如果距离上次请求的时间不足2小时
            if (($currentTime - $lastRequestTime) < $limitDuration) {
                return redirect()->back()->with('error', '您已提交过请求,请在2小时后再次尝试。');
            }
        }

        // 如果没有上次请求时间戳,或者已超过2小时,则允许提交
        // 执行提款请求的创建逻辑
        $withDraw = WithdrawWallet::create([
            'balance_value' => $request->balance_wallet,
            'can_draw' => $request->can_draw,
            'shaba_number' => $request->shaba_number,
            'first_name' => $request->first_name,
            'last_name' => $request->last_name,
            'description' => $request->desc,
            'status' => 'pending',
            'user_id' => auth()->user()->usr_id,
        ]);

        // 请求成功后,更新会话中的时间戳
        Session::put($sessionKey, now()->timestamp);

        return redirect()->back()->with('success', '您的请求已成功发送。');
    }
}

代码解析:

  1. 定义会话键和限制时长: 我们定义了一个唯一的会话键 last_withdraw_request_time 和一个 limitDuration 来表示2小时的秒数。
  2. 检查上次请求时间: 使用 Session::has($sessionKey) 检查会话中是否存在上次请求的时间戳。
  3. 计算时间差: 如果存在,我们获取 lastRequestTime 和当前的 currentTime,并计算它们之间的秒数差。
  4. 执行限流判断: 如果时间差小于 limitDuration,则表示用户在限制时间内再次提交,直接返回错误信息。
  5. 处理请求并更新时间戳: 如果通过了限流检查,则执行实际的业务逻辑(创建提款记录),并在成功后,使用 Session::put($sessionKey, now()-youjiankuohaophpcntimestamp) 更新会话中的时间戳为当前时间。

注意事项与最佳实践

  • 会话生命周期: Laravel的会话默认是基于Cookie的,其生命周期通常与浏览器会话相关,或者有一个配置的过期时间(例如 config/session.php 中的 lifetime)。如果用户清除Cookie或会话过期,限流机制将失效。
  • 用户认证: 上述示例假设用户已登录 (auth()->user()->usr_id)。对于未登录用户,也可以使用会话,但其稳定性不如已认证用户。
  • 更复杂的限流: 对于生产环境或高并发场景,仅仅依赖会话可能不够健壮。可以考虑以下替代方案:
    • 缓存(Cache): 使用 Redis 或 Memcached 等缓存系统存储用户ID和请求时间,设置过期时间。这比会话更持久且可跨服务器共享。
    • 数据库: 在数据库中记录每次请求的时间,每次提交前查询数据库。
    • Laravel Rate Limiter: Laravel内置了强大的限流功能,通常通过中间件实现,可以基于IP、用户ID等进行更灵活的限流策略。例如,throttle 中间件。
  • 用户体验: 在返回错误信息时,确保信息清晰友好,告知用户何时可以再次尝试。

总结

正确使用 Session::put() 方法是实现基于会话功能的关键。始终记住 Session::put() 需要一个键和一个值。通过结合时间戳,我们可以利用Laravel会话机制实现简单的请求限流,有效控制用户行为。然而,对于更严格或更复杂的限流需求,建议考虑使用Laravel内置的限流器或缓存系统,以提供更稳定和可扩展的解决方案。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

340

2024.04.09

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

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

294

2024.04.09

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

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

774

2024.04.09

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

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

386

2024.04.10

laravel入门教程
laravel入门教程

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

146

2025.08.05

laravel实战教程
laravel实战教程

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

85

2025.08.05

laravel面试题
laravel面试题

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

81

2025.08.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

659

2026.03.04

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

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

精品课程

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

共137课时 | 13.6万人学习

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

共6课时 | 11.3万人学习

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

共13课时 | 1.0万人学习

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

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