Laravel 5 控制器如何实现基于自身的中间件
声明:本文由夭℃~空投稿,未经作者许可,禁止转载!
这个想法的产生背景是在我碰到一个实际需求的时候。当时我碰到了这么一个需求:
首先我有很多模块,每个模块都有一个鉴权方式。
我本来想用中间件来做,但是随即发现,由于每个模块的过滤方式不一样导致中间件的数量一下子增加了很多。而且,由于中间件的分离到了中间件的文件夹去,且并不能实现中间件的复用价值。所以,我抛弃了使用中间件的方法。
这个时候,我想到,每个控制器自己有独立的 construct不就好了,这样每个控制器都有自己的独特的鉴权方式。
但是问题随之而来,Laravel 的控制器虽然能实现自动 construct,但是在 construct里面的,并不能实现 response,也就是说在 construct里面的 response将会被忽略。不是实现返回错误信息,或者重定向的需求。
翻了文档之后似乎找不到一个完美的解决方法。于是,我去翻源代码,最终把目标放 beforeFilter,并用 boforeFilter实现了这个需求。
重新整理适用场景:
本用法适用于每个控制器都需要同样的一套过滤,而具体的过滤方式由控制器自身决定,也就是基于控制器本身的中间件。
代码如下:
首先建立一个基础的控制器:
<?phpnamespace App\Http\Controllers\Api\Business;use RuntimeException;use Illuminate\Routing\Controller as BaseController;use Illuminate\Auth\Guard;use Illuminate\Http\Request;abstract class Controller extends BaseController{ protected $request; protected $auth; public function __construct(Request $request,Guard $auth){ $this->request = $request; $this->auth = $auth; //统一鉴权 $this->beforeFilter(function(){ return $this->checkPermission(); }); } protected function checkPermission(){ throw new RuntimeException('['.get_class($this).'] missing method[checkPermission]'); }}
将 request和 auth放到基础控制器,是为了方便鉴权过程中调用,关键的地方,在于设置 beforeFilter,通过 beforeFilter调用控制器自身的协议方法。至于我在基础控制器里面放 checkPermission是要求所有基于这个控制器的控制器必须重载掉这个方法。 beforeFilter可以设置第二个参数,跟 middleware()一样,可以设置 except或者 only。
然后定义模块控制器继承这个方法:
<?phpnamespace App\Http\Controllers\Api\Business;class TicketController extends Controller{ //鉴定权限 protected function checkPermission(){ //return redirect()->to('某个url'); //return view(); //return 'string'; ... }}
只要 checkPermission里面返回 response,那么就会跟中间件一样作为整个请求的 response.如果里面不返回任何东西,那么php会自动返回 null。只要是 null,就代表着通过 checkPermission的验证。
这样就能实现基于控制器自身的中间件,更多用法有待发掘。
注:目前这个我在5.0版本使用通过,更高的版本有待测试。
本文由夭℃~空投稿,他邮箱是 anwelblue@qq.com,有什么问题欢迎与他一起探讨,此外你还可以在学院二群找到他: 542175836。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

JWT是一种基于JSON的开放标准,用于在各方之间安全地传输信息,主要用于身份验证和信息交换。1.JWT由Header、Payload和Signature三部分组成。2.JWT的工作原理包括生成JWT、验证JWT和解析Payload三个步骤。3.在PHP中使用JWT进行身份验证时,可以生成和验证JWT,并在高级用法中包含用户角色和权限信息。4.常见错误包括签名验证失败、令牌过期和Payload过大,调试技巧包括使用调试工具和日志记录。5.性能优化和最佳实践包括使用合适的签名算法、合理设置有效期、

文章讨论了PHP 5.3中引入的PHP中的晚期静态结合(LSB),从而允许静态方法的运行时分辨率调用以获得更灵活的继承。 LSB的实用应用和潜在的触摸

使用PHP的cURL库发送JSON数据在PHP开发中,经常需要与外部API进行交互,其中一种常见的方式是使用cURL库发送POST�...

SOLID原则在PHP开发中的应用包括:1.单一职责原则(SRP):每个类只负责一个功能。2.开闭原则(OCP):通过扩展而非修改实现变化。3.里氏替换原则(LSP):子类可替换基类而不影响程序正确性。4.接口隔离原则(ISP):使用细粒度接口避免依赖不使用的方法。5.依赖倒置原则(DIP):高低层次模块都依赖于抽象,通过依赖注入实现。

会话劫持可以通过以下步骤实现:1.获取会话ID,2.使用会话ID,3.保持会话活跃。在PHP中防范会话劫持的方法包括:1.使用session_regenerate_id()函数重新生成会话ID,2.通过数据库存储会话数据,3.确保所有会话数据通过HTTPS传输。
