中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

在非Laravel項目中使用Validator驗證器的案例

發布時間:2021-02-19 09:38:08 來源:億速云 閱讀:170 作者:小新 欄目:編程語言

這篇文章主要介紹在非Laravel項目中使用Validator驗證器的案例,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

安裝

composer require illuminate/validation

引入提示消息

項目根目錄創建 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只能包含字母、數字、中劃線或下劃線',
'alpha_num'            => ':attribute只能包含字母和數字',
'array'                => ':attribute必須是一個數組',
'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 項之間',
],
'boolean'              =>':attribute字符必須是 true 或false, 1 或 0 ',
'confirmed'            => ':attribute 二次確認不匹配',
'date'                 => ':attribute 必須是一個合法的日期',
'date_format'          => ':attribute 與給定的格式 :format 不符合',
'different'            => ':attribute 必須不同于 :other',
'digits'               => ':attribute必須是 :digits 位.',
'digits_between'       => ':attribute 必須在 :min 和 :max 位之間',
'dimensions'           => ':attribute具有無效的圖片尺寸',
'distinct'             => ':attribute字段具有重復值',
'email'                => ':attribute必須是一個合法的電子郵件地址',
'exists'               => '選定的 :attribute 是無效的.',
'file'                 => ':attribute必須是一個文件',
'filled'               => ':attribute的字段是必填的',
'image'                => ':attribute必須是 jpeg, png, bmp 或者 gif 格式的圖片',
'in'                   => '選定的 :attribute 是無效的',
'in_array'             => ':attribute 字段不存在于 :other',
'integer'              => ':attribute 必須是個整數',
'ip'                   => ':attribute必須是一個合法的 IP 地址。',
'json'                 => ':attribute必須是一個合法的 JSON 字符串',
'max'                  => [
    'numeric' => ':attribute 的最大長度為 :max 位',
    'file'    => ':attribute 的最大為 :max',
    'string'  => ':attribute 的最大長度為 :max 字符',
    'array'   => ':attribute 的最大個數為 :max 個.',
],
'mimes'                => ':attribute 的文件類型必須是 :values',
'min'                  => [
    'numeric' => ':attribute 的最小長度為 :min 位',
    'file'    => ':attribute 大小至少為 :min KB',
    'string'  => ':attribute 的最小長度為 :min 字符',
    'array'   => ':attribute 至少有 :min 項',
],
'not_in'               => '選定的 :attribute 是無效的',
'numeric'              => ':attribute 必須是數字',
'present'              => ':attribute 字段必須存在',
'regex'                => ':attribute 格式是無效的',
'required'             => ':attribute 字段是必須的',
'required_if'          => ':attribute 字段是必須的當 :other 是 :value',
'required_unless'      => ':attribute 字段是必須的,除非 :other 是在 :values 中',
'required_with'        => ':attribute 字段是必須的當 :values 是存在的',
'required_with_all'    => ':attribute 字段是必須的當 :values 是存在的',
'required_without'     => ':attribute 字段是必須的當 :values 是不存在的',
'required_without_all' => ':attribute 字段是必須的當 沒有一個 :values 是存在的',
'same'                 => ':attribute和:other必須匹配',
'size'                 => [
    'numeric' => ':attribute 必須是 :size 位',
    'file'    => ':attribute 必須是 :size KB',
    'string'  => ':attribute 必須是 :size 個字符',
    'array'   => ':attribute 必須包括 :size 項',
],
'string'               => ':attribute 必須是一個字符串',
'timezone'             => ':attribute 必須是個有效的時區.',
'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 定位到剛剛創建的 lang 目錄

  • $translation_locale 為多語言目錄名,即 zh_cn

namespace App\handlers;


class Validator extends \Illuminate\Validation\Factory
{
    /***
     * 創建實例
     *
     * @return \Illuminate\Validation\Factory
     */

    public static function getInstance()
    {
        static $validator = null;
        if ($validator === null) {
            $translation_path = __DIR__ . '/../lang';
            $translation_locale = 'zh_cn';
            $translation_file_loader = new \Illuminate\Translation\FileLoader(new \Illuminate\Filesystem\Filesystem,
                $translation_path);
            $translator = new \Illuminate\Translation\Translator($translation_file_loader, $translation_locale);
            $validator = new \Illuminate\Validation\Factory($translator);
        }
        return $validator;
    }
}

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

使用

直接使用

// 接參
$data['title']      =  '123';
$data['content']    = '123';

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

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

// 接參
$data['title']      =  '123';
$data['content']    = '123';

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

打印錯誤消息

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

以上是“在非Laravel項目中使用Validator驗證器的案例”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

名山县| 杂多县| 莫力| 平罗县| 山西省| 阿拉善右旗| 湄潭县| 河池市| 双辽市| 达日县| 宣城市| 丰原市| 青田县| 城口县| 青河县| 上饶县| 县级市| 济南市| 吉安县| 沂源县| 确山县| 乡城县| 黄龙县| 连山| 迭部县| 彩票| 乌兰浩特市| 信宜市| 贺州市| 长兴县| 巩留县| 合水县| 松滋市| 巨野县| 大丰市| 宁夏| 承德县| 旬邑县| 绥德县| 东方市| 正蓝旗|