在非Laravel項(xiàng)目中怎么使用Validator驗(yàn)證器

下面由laravel教程欄目給大家介紹在非laravel項(xiàng)目中使用validator驗(yàn)證器的方法 ,希望對需要的朋友有所幫助!

在非Laravel項(xiàng)目中怎么使用Validator驗(yàn)證器

安裝

composer require illuminate/validation

引入提示消息

項(xiàng)目根目錄創(chuàng)建 lang/zh_cn/validation.php 文件

<?php  return [  /* |-------------------------------------------------------------------------- | Validation Language Lines |-------------------------------------------------------------------------- | | The following language lines contain the default error messages used by | the validator class. Some of these rules have multiple versions such | as the size rules. Feel free to tweak each of these messages here. | */  'accepted'             => ':attribute必須接受', 'active_url'           => ':attribute必須是一個合法的 URL', 'after'                => ':attribute 必須是 :date 之后的一個日期', 'after_or_equal'       => ':attribute 必須是 :date 之后或相同的一個日期', 'alpha'                => ':attribute只能包含字母', 'alpha_dash'           => ':attribute只能包含字母、數(shù)字、中劃線或下劃線', 'alpha_num'            => ':attribute只能包含字母和數(shù)字', 'array'                => ':attribute必須是一個數(shù)組', 'before'               => ':attribute 必須是 :date 之前的一個日期', 'before_or_equal'      => ':attribute 必須是 :date 之前或相同的一個日期', 'between'              => [     'numeric' => ':attribute 必須在 :min 到 :max 之間',     'file'    => ':attribute 必須在 :min 到 :max KB 之間',     'string'  => ':attribute 必須在 :min 到 :max 個字符之間',     'array'   => ':attribute 必須在 :min 到 :max 項(xiàng)之間', ], 'boolean'              =>':attribute字符必須是 true 或false, 1 或 0 ', 'confirmed'            => ':attribute 二次確認(rèn)不匹配', 'date'                 => ':attribute 必須是一個合法的日期', 'date_format'          => ':attribute 與給定的格式 :format 不符合', 'different'            => ':attribute 必須不同于 :other', 'digits'               => ':attribute必須是 :digits 位.', 'digits_between'       => ':attribute 必須在 :min 和 :max 位之間', 'dimensions'           => ':attribute具有無效的圖片尺寸', 'distinct'             => ':attribute字段具有重復(fù)值', 'email'                => ':attribute必須是一個合法的電子郵件地址', 'exists'               => '選定的 :attribute 是無效的.', 'file'                 => ':attribute必須是一個文件', 'filled'               => ':attribute的字段是必填的', 'image'                => ':attribute必須是 jpeg, png, bmp 或者 gif 格式的圖片', 'in'                   => '選定的 :attribute 是無效的', 'in_array'             => ':attribute 字段不存在于 :other', 'integer'              => ':attribute 必須是個整數(shù)', 'ip'                   => ':attribute必須是一個合法的 IP 地址。', 'json'                 => ':attribute必須是一個合法的 JSON 字符串', 'max'                  => [     'numeric' => ':attribute 的最大長度為 :max 位',     'file'    => ':attribute 的最大為 :max',     'string'  => ':attribute 的最大長度為 :max 字符',     'array'   => ':attribute 的最大個數(shù)為 :max 個.', ], 'mimes'                => ':attribute 的文件類型必須是 :values', 'min'                  => [     'numeric' => ':attribute 的最小長度為 :min 位',     'file'    => ':attribute 大小至少為 :min KB',     'string'  => ':attribute 的最小長度為 :min 字符',     'array'   => ':attribute 至少有 :min 項(xiàng)', ], 'not_in'               => '選定的 :attribute 是無效的', 'numeric'              => ':attribute 必須是數(shù)字', 'present'              => ':attribute 字段必須存在', 'regex'                => ':attribute 格式是無效的', 'required'             => ':attribute 字段是必須的', 'required_if'          => ':attribute 字段是必須的當(dāng) :other 是 :value', 'required_unless'      => ':attribute 字段是必須的,除非 :other 是在 :values 中', 'required_with'        => ':attribute 字段是必須的當(dāng) :values 是存在的', 'required_with_all'    => ':attribute 字段是必須的當(dāng) :values 是存在的', 'required_without'     => ':attribute 字段是必須的當(dāng) :values 是不存在的', 'required_without_all' => ':attribute 字段是必須的當(dāng) 沒有一個 :values 是存在的', 'same'                 => ':attribute和:other必須匹配', 'size'                 => [     'numeric' => ':attribute 必須是 :size 位',     'file'    => ':attribute 必須是 :size KB',     'string'  => ':attribute 必須是 :size 個字符',     'array'   => ':attribute 必須包括 :size 項(xiàng)', ], 'string'               => ':attribute 必須是一個字符串', 'timezone'             => ':attribute 必須是個有效的時區(qū).', 'unique'               => ':attribute 已存在', 'url'                  => ':attribute 無效的格式',  /* |-------------------------------------------------------------------------- | Custom Validation Language Lines |-------------------------------------------------------------------------- | | Here you may specify custom validation messages for attributes using the | convention "attribute.rule" to name the lines. This makes it quick to | specify a specific custom language line for a given attribute rule. | */  'custom' => [     'attribute-name' => [         'rule-name' => 'custom-message',     ], ],  /* |-------------------------------------------------------------------------- | Custom Validation Attributes |-------------------------------------------------------------------------- | | The following language lines are used to swap attribute place-holders | with something more reader friendly such as E-Mail Address instead | of "email". This simply helps us make messages a little cleaner. | */  'attributes' => [    // 'name'         => '名字',    // 'age'         => '年齡', ],  ];

來自:https://learnku.com/articles/5840/validation-validation-in-laravel-returns-chinese-prompt#reply104522

封裝 handler

封裝 handler

  • $translation_path 定位到剛剛創(chuàng)建的 lang 目錄
  • $translation_locale 為多語言目錄名,即 zh_cn
namespace Apphandlers;   class Validator extends IlluminateValidationFactory {     /***      * 創(chuàng)建實(shí)例      *      * @return IlluminateValidationFactory      */      public static function getInstance()     {         static $validator = null;         if ($validator === null) {             $translation_path = __DIR__ . '/../lang';             $translation_locale = 'zh_cn';             $translation_file_loader = new IlluminateTranslationFileLoader(new IlluminateFilesystemFilesystem,                 $translation_path);             $translator = new IlluminateTranslationTranslator($translation_file_loader, $translation_locale);             $validator = new IlluminateValidationFactory($translator);         }         return $validator;     } }

參考:http://www.xiaosongit.com/index/detail/id/897.html

使用

直接使用

// 接參 $data['title']      =  '123'; $data['content']    = '123';  // 驗(yàn)證 $validator = Validator::getInstance()->make($data, [     'title' => 'required|min:10',     'content' => 'required|min:10', ]);

自定義消息提示和定義屬性名稱

// 接參 $data['title']      =  '123'; $data['content']    = '123';  // 規(guī)則 $rules = [     'title' => 'required|min:10',     'content' => 'required|min:10', ]; // 自定義消息提示 $messages = [     'title.required' => ':title字段必須' ]; //屬性名稱 $attributes = [     'title' => '標(biāo)題',     'content' => '內(nèi)容', ]; // 驗(yàn)證 $validator = Validator::getInstance()->make($data, $rules, $message, $attributes);

打印錯誤消息

if ($validator->fails()) {     print_r($validator->errors()->all()); }

PS:驗(yàn)證規(guī)則請前往 Laravel Validator 文檔查看

finish!

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊14 分享