您现在的位置是:网站首页> 编程资料编程资料

Yii中特殊行为ActionFilter的使用方法示例_php实例_

2023-05-25 315人已围观

简介 Yii中特殊行为ActionFilter的使用方法示例_php实例_

新建 app\filters\LoggingFilter 继承 yii\base\ActionFilter

LoggingFilter 的功能: 在指定请求的 action 前后各记录一条日志

getActionId($action), PHP_EOL); return true; } public function afterAction($action, $result) { parent::afterAction($action, $result); // To do something printf('This is a logging for %s\afterAction.%s', $this->getActionId($action), PHP_EOL); return true; } }

新建 app\controllers\SystemController

 [ 'class' => LoggingFilter::className(), 'only' => ['test', 'test-one'], // 仅对 'test'、'test-one' 生效 'except' => ['test-one'], // 排除 'test-one' ], ]; } public function actionTestOne() { printf('This is a testing for %s.%s', $this->getRoute(), PHP_EOL); } public function actionTestTwo() { printf('This is a testing for %s.%s', $this->getRoute(), PHP_EOL); } public function actionTest() { printf('This is a testing for %s.%s', $this->getRoute(), PHP_EOL); } }

测试

请求 http://yii.test/index.php?r=system/test

 This is a logging for test\beforeAction. This is a testing for system/test. This is a logging for test\afterAction.

请求 http://yii.test/index.php?r=system/test-one

 This is a testing for system/test-one.

请求 http://yii.test/index.php?r=system/test-two

 This is a testing for system/test-two.

总结

Yii 中的 ActionFilter(过滤器)相当于 Laravel 中的 Middleware(中间件),beforeAction 相当于前置中间件,afterAction 相当于后置中间件。

到此这篇关于Yii中特殊行为ActionFilter使用的文章就介绍到这了,更多相关Yii特殊行为ActionFilter使用内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

-六神源码网