思路講解:不管是在開發 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 思想的參數驗證就完成了。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- ThinkPHP5 框架引入 Go AOP,PHP AOP編程項目詳解
- php筆記之:AOP的應用
- PHP三層結構(下) PHP實現AOP
- PHP AOP教程案例