思路講解:不管是在開發(fā) API 還是做后臺(tái)項(xiàng)目的時(shí)候,后端永遠(yuǎn)不要相信前端傳輸?shù)膮?shù),通常要做的是驗(yàn)證參數(shù)的合法性和安全性。那么在實(shí)際項(xiàng)目開發(fā)的時(shí)候,怎么簡(jiǎn)便的驗(yàn)證參數(shù)呢。TP 提供了好幾種參數(shù)驗(yàn)證的方式,比如驗(yàn)證器,獨(dú)立驗(yàn)證,又或者在繼承 Controller 基類的情況下使用 validate 方法。相比而言,驗(yàn)證器還是最佳選擇。一個(gè)控制器有多個(gè)方法,也就表示有多個(gè)請(qǐng)求,也就表示有多個(gè)場(chǎng)景。一個(gè)項(xiàng)目不止一個(gè)控制器,那就表示不止需要建立一個(gè)驗(yàn)證器。面向?qū)ο蟮乃枷?,就需要我們建立一個(gè)基類驗(yàn)證器,然后讓子類繼承就行了。那么怎么實(shí)現(xiàn)參數(shù)驗(yàn)證呢,下面我就介紹下類似 AOP 思想的參數(shù)驗(yàn)證的實(shí)現(xiàn)。
定義驗(yàn)證器基類
定義基類 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;
}
//自定義驗(yàn)證規(guī)則
}
定義驗(yàn)證器
?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個(gè)字符',
'age.number' => '年齡必須是數(shù)字',
'age.between' => '年齡只能在1-120之間',
'email' => '郵箱格式錯(cuò)誤',
];
protected $scene = [
'register' => ['name','email'],
];
}
驗(yàn)證參數(shù)
User.php 控制器 register 方法,實(shí)例化驗(yàn)證器,并進(jìn)行場(chǎng)景驗(yàn)證。
public function register(Request $request){
$validator = new UserValidator();
$validator->checkParams('register');
.
.
.
}
至此,類似于 AOP 思想的參數(shù)驗(yàn)證就完成了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- ThinkPHP5 框架引入 Go AOP,PHP AOP編程項(xiàng)目詳解
- php筆記之:AOP的應(yīng)用
- PHP三層結(jié)構(gòu)(下) PHP實(shí)現(xiàn)AOP
- PHP AOP教程案例