Как сделать проверку нескольких полей в Laravel? - PullRequest
0 голосов
/ 29 июня 2018

Все остальные проверки работают нормально, но я должен подтвердить номер мобильного телефона с уникальным кодом страны и сгенерируйте специальное сообщение проверки. Пожалуйста, помогите мне.

    $validator = Validator::make($request->all(), [
        'first_name'=> 'required|min:2|max:30',
        'last_name' => 'required|min:2|max:30',
        'email'     => 'required|unique:users,email,'.$userId,
        'mobile'    => 'required|numeric|min:10|unique:users,mobile,'.$userId,
    ]);
if ($validator->fails()){
            $response['status'] = "false"; 
            $response['message'] = $this->validationHandle($validator->messages());  
            $response['data'] = []; 
            $this->response($response);
        }else{
//true function response
}

Ответы [ 2 ]

0 голосов
/ 29 июня 2018

Сначала включите класс правил в верхней части контроллера, затем измените валидацию, как показано ниже для мобильного телефона.

use Illuminate\Validation\Rule;
    $validator = Validator::make($request->all(), [
            'first_name'        => 'required',
            'last_name'         => 'required',
            'email'             => 'required|unique:users',
            'mobile'            => ["required","numeric","min:7",Rule::unique('users')->where(function ($query)use ($request) {
                                        return $query->where('country_id',"=", $request->country_id);
                                    })],
            'country_id'        => 'required|numeric',
            'password'          => 'required|min:8|max:15',
            'account_type'      => 'required',
            'device_type'       => 'required',
            'device_token'      => 'required',
        ]); 

Надеюсь, что вы получите правильный ответ. (У)

0 голосов
/ 29 июня 2018

Вы можете создать свой собственный валидатор для этого сценария:

  Validator::extend('custom_unique',

         function ($attribute, $value, $parameters, $validator) {

         // Get table name from first parameter
            $table = array_shift($parameters);

        // Build the query
           $query = DB::table($table);

       // Add the field conditions
          foreach ($parameters as $i => $field) {
            $query->where($field, $validator->getData()[$field]);
          }

      // Validation result will be false if any rows match the combination
          return ($query->count() == 0);

   });

И вы можете использовать его:

 //table_name - users 
 //fields -  user_id,mobile_no,etc..
'mobile' => 'required|numeric|min:10|custom_unique:users,user_id,mobile_no'...
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...