Yii中特殊行为ActionFilter的使用方法示例
新建app\filters\LoggingFilter继承yii\base\ActionFilter
LoggingFilter的功能:在指定请求的action前后各记录一条日志
getActionId($action),PHP_EOL); returntrue; } publicfunctionafterAction($action,$result) { parent::afterAction($action,$result); //Todosomething printf('Thisisaloggingfor%s\afterAction.%s',$this->getActionId($action),PHP_EOL); returntrue; } }
新建app\controllers\SystemController
[ 'class'=>LoggingFilter::className(), 'only'=>['test','test-one'],//仅对'test'、'test-one'生效 'except'=>['test-one'],//排除'test-one' ], ]; } publicfunctionactionTestOne() { printf('Thisisatestingfor%s.%s',$this->getRoute(),PHP_EOL); } publicfunctionactionTestTwo() { printf('Thisisatestingfor%s.%s',$this->getRoute(),PHP_EOL); } publicfunctionactionTest() { printf('Thisisatestingfor%s.%s',$this->getRoute(),PHP_EOL); } }
测试
请求http://yii.test/index.php?r=system/test
Thisisaloggingfortest\beforeAction. Thisisatestingforsystem/test. Thisisaloggingfortest\afterAction.
请求http://yii.test/index.php?r=system/test-one
Thisisatestingforsystem/test-one.
请求http://yii.test/index.php?r=system/test-two
Thisisatestingforsystem/test-two.
总结
Yii中的ActionFilter(过滤器)相当于Laravel中的Middleware(中间件),beforeAction相当于前置中间件,afterAction相当于后置中间件。
到此这篇关于Yii中特殊行为ActionFilter使用的文章就介绍到这了,更多相关Yii特殊行为ActionFilter使用内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。