您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關ThinkPHP中如何實現類似AOP思想的參數驗證的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
思路講解:不管是在開發 API 還是做后臺項目的時候,后端永遠不要相信前端傳輸的參數,通常要做的是驗證參數的合法性和安全性。那么在實際項目開發的時候,怎么簡便的驗證參數呢。TP 提供了好幾種參數驗證的方式,比如驗證器,獨立驗證,又或者在繼承 Controller 基類的情況下使用 validate 方法。相比而言,驗證器還是最佳選擇。一個控制器有多個方法,也就表示有多個請求,也就表示有多個場景。一個項目不止一個控制器,那就表示不止需要建立一個驗證器。面向對象的思想,就需要我們建立一個基類驗證器,然后讓子類繼承就行了。那么怎么實現參數驗證呢,下面我就介紹下類似 AOP 思想的參數驗證的實現。
定義驗證器基類
定義基類 app\common\validator\BaseValidator.php
<?php namespace app\common\validator; use app\common\exception\ParamException; use think\Validate; class BaseValidator extends Validate { /** * @param string $scene * @return bool * @throws ParamException */ public function checkParams($scene='') { $params = input('param.'); $res = $this->scene($scene)->check($params); if( ! $res ){ $error = $this->error; if(is_array($error)){ $error = implode(',',$error); } throw new ParamException(['errMsg'=>$error,]); } return $res; } //自定義驗證規則 }
定義驗證器
<?php namespace app\common\validator\user; use app\common\validator\BaseValidator; class UserValidator extends BaseValidator { protected $rule = [ 'name' => 'require|max:25', 'age' => 'number|between:1,120', 'email' => 'email', ]; protected $message = [ 'name.require' => '名稱必須', 'name.max' => '名稱最多不能超過25個字符', 'age.number' => '年齡必須是數字', 'age.between' => '年齡只能在1-120之間', 'email' => '郵箱格式錯誤', ]; protected $scene = [ 'register' => ['name','email'], ]; }
驗證參數
User.php 控制器 register 方法,實例化驗證器,并進行場景驗證。
public function register(Request $request){ $validator = new UserValidator(); $validator->checkParams('register'); . . . }
至此,類似于 AOP 思想的參數驗證就完成了。
感謝各位的閱讀!關于“ThinkPHP中如何實現類似AOP思想的參數驗證”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。