Laravel的throttle中间件失效问题解决方法
作者:hxx_yang
这篇文章主要介绍了Laravel的throttle中间件失效问题解决方法,简单分析了throttle中间件失效问题的原因并提出了解决方案,具有一定参考借鉴价值,需要的朋友可以参考下
本文实例讲述了Laravel的throttle中间件失效问题解决方法。分享给大家供大家参考,具体如下:
按官方解释,实现访问频率限制非常简单:
Route::get('test', function(){ return 'helle world' ; })->middleware('throttle');
也确实如此,cache存储访问次数,做出判断。
之前使用了zizaco/entrust(一个基于角色的权限管理包),其中把 .env 中的CACHE_DRIVER=file 改为了 CACHE_DRIVER=array。所以问题出现了。Laravel支持多种cache驱动,File, Array, Db, Redis等,但是throttle 好像使用File类型的驱动才有效。
我的修改如下:
vendor/illuminate/cache/RateLimiter.php 文件
public function __construct(Cache $cache) { $this->cache = $cache; } public function __construct() { $this->cache = app('cache')->driver('file'); }
把上面的改为下面的就可以了。throttle中间件也起作用了。
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php日期与时间用法总结》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
您可能感兴趣的文章:
- Laravel中间件实现原理详解
- Laravel框架实现利用中间件进行操作日志记录功能
- Laravel获取当前请求的控制器和方法以及中间件的例子
- laravel框架中间件 except 和 only 的用法示例
- Laravel框架基于中间件实现禁止未登录用户访问页面功能示例
- 浅谈Laravel中的三种中间件的作用
- Laravel5.1框架注册中间件的三种场景详解
- laravel利用中间件防止未登录用户直接访问后台的方法
- laravel利用中间件做防非法登录和权限控制示例
- 基于Laravel 多个中间件的执行顺序详解
- Laravel5.1 框架Middleware中间件基本用法实例分析
- laravel框架中间件简单使用方法示例