本文實例講述了thinkPHP5框架自定義驗證器實現(xiàn)方法。分享給大家供大家參考,具體如下:
普通的驗證器手冊上已經(jīng)很詳細(xì),我們講解一下如何自定義一個驗證器
首先我們在模塊目錄下建立validata文件夾
然后在里面建立一個類,取名為IdMustInt.php
代碼如下:注意,我的模塊名為api,所以命名空間如下
保護(hù)屬性$rule為官方規(guī)定,不能改變,其實驗證規(guī)則require都是封裝好的函數(shù)名,所以我們也建立一個方法,方法名填寫在驗證規(guī)則后面即可
namespace app\api\validate;
use think\Validate;
class IdMustInt extends Validate
{
protected $rule = [
'id' => 'require|IsInt'
];
protected function IsInt($value,$rule,$data,$field){
//參數(shù)依次為驗證數(shù)據(jù),驗證規(guī)則,全部數(shù)據(jù)(數(shù)組),字段名
//這里我們要判斷的驗證的數(shù)據(jù)要求必須為正整型
if(is_numeric($value) is_int($value+0) ($value+0) > 0){
return true;
}else{
//如果不符合我們的條件,返回錯誤信息,在控制器中可以用getError()方法輸出
return $field.'不是整型';
}
}
}
接下來看我們控制器的對應(yīng)操作
public function getBanner($id)
{
//需要驗證的數(shù)據(jù)
$data = [
'id' => $id,
];
//實例化驗證器
$validate = new IdMustInt();
//如果驗證數(shù)據(jù)較多,條件也較多,需要批量返回所有錯誤信息的話,可以在check()前加上$validata->batch()
$result = $validate->check($data);
if($result){
//業(yè)務(wù)邏輯
}else{
dump($validate->getError());
}
}
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門教程》、《CI(CodeIgniter)框架進(jìn)階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對大家基于ThinkPHP框架的PHP程序設(shè)計有所幫助。
您可能感興趣的文章:- ThinkPHP5 驗證器的具體使用
- Thinkphp5 微信公眾號token驗證不成功的原因及解決方法
- thinkphp5.0自定義驗證規(guī)則使用方法
- tp5(thinkPHP5框架)captcha驗證碼配置及驗證操作示例
- 學(xué)習(xí)thinkphp5.0驗證類使用方法
- thinkphp5框架API token身份驗證功能示例
- thinkPHP5.0框架驗證碼調(diào)用及點擊圖片刷新簡單實現(xiàn)方法
- thinkphp5使用bootstrapvalidator進(jìn)行異步驗證郵箱的示例
- ThinkPHP5.0框架驗證碼功能實現(xiàn)方法【基于第三方擴(kuò)展包】
- Thinkphp5框架使用validate實現(xiàn)驗證功能的方法