当前位置:首页 > CMS教程 > 其它CMS > 列表

laravel unique验证、确认密码confirmed验证以及密码修改验证的方法

发布:smiling 来源: PHP粉丝网  添加日期:2022-01-05 14:55:09 浏览: 评论:0 

这篇文章主要介绍了laravel unique验证、确认密码confirmed验证以及密码修改验证的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。

confirmed

验证字段必须有一个匹配字段 foo_confirmation,例如,如果验证字段是 password,必须输入一个与之匹配的 password_confirmation 字段。

same:field

给定字段和验证字段必须匹配

  1. protected $fillable = ['name''password']; 
  2.  
  3. public static $rules = [ 
  4.  'name'   => 'required|unique:managers'
  5.  'password' => 'required|confirmed'
  6.  'password_confirmation' => 'required|same:password' 
  7. ]; 
  8.  
  9. public static function error_message()  
  10.  return [ 
  11.   'name.required' => __('tyvalidation.name'), 
  12.   'name.unique' => __('tyvalidation.unique'), 
  13.   'password.required' => __('tyvalidation.password'), 
  14.   'password.confirmed' => __('tyvalidation.confirmed'), 
  15.  ]; 
  16.  
  17. public function setPasswordAttribute($value
  18.  $this->attributes['password'] = Hash::make($value); 

经验证,上面的验证方式在update的时候会出问题,修改的时候会验证unique,导致不能保存,所以需要修改下。

官网说:

Sometimes, you may wish to ignore a given ID during the unique check. For example, consider an "update profile" screen that includes the user's name, e-mail address, and location. Of course, you will want to verify that the e-mail address is unique. However, if the user only changes the name field and not the e-mail field, you do not want a validation error to be thrown because the user is already the owner of the e-mail address.

To instruct the validator to ignore the user's ID, we'll use the Rule class to fluently define the rule. In this example, we'll also specify the validation rules as an array instead of using the |character to delimit the rules:

重要的2句话是:

有时,您可能希望在唯一检查期间忽略给定的ID。

当然,您需要验证电子邮件地址是否唯一。但是,如果用户仅更改名称字段而不更改电子邮件字段,则不希望抛出验证错误,因为用户已经是电子邮件地址的所有者,为了指示验证者忽略用户的ID,我们将使用Rule该类来流畅地定义规则。

  1. use Illuminate\Validation\Rule; 
  2.    
  3. Validator::make($data, [ 
  4.   'email' => [ 
  5.     'required'
  6.     Rule::unique('users')->ignore($user->id), 
  7.   ], 
  8. ]); 

所以修改为

  1. 'name'   => [ 
  2.      'required'
  3.      Rule::unique('managers')->ignore($id), 
  4.     ], 

在更新密码时,我们需要验证旧的密码是否正确,那我们需要使用自定义验证。

Using Closures

If you only need the functionality of a custom rule once throughout your application, you may use a Closure instead of a rule object. The Closure receives the attribute's name, the attribute's value, and a $fail callback that should be called if validation fails:

Closure接收属性的名称,属性的值以及$fail在验证失败时应调用的回调。

  1. $validator = Validator::make($request->all(), [ 
  2.   'title' => [ 
  3.     'required'
  4.     'max:255'
  5.     function($attribute$value$fail) { 
  6.       if ($value === 'foo') { 
  7.         return $fail($attribute.' is invalid.'); 
  8.       } 
  9.     }, 
  10.   ], 
  11. ]); 

所以密码是否正确可以这样验证

  1. 'old_password' => [ 
  2.      'required'
  3.      function($attribute$value$failuse ($manager)  
  4.      { 
  5.       if (!Hash::check($value$manager->password))  
  6.       { 
  7.        return $fail(__('tyvalidation.old_password')); 
  8.       } 
  9.      }, 
  10.     ], 

所有代码如下:

create.html

  1. <div class="form-group"
  2.       <label>{!! __('tycms.name') !!}</label> 
  3.       <div class="input-group"
  4.        <div class="input-group-prepend"
  5.         <span class="input-group-text change-bg">T</span> 
  6.        </div> 
  7.        <input type="text" class="form-control is-invalid" name="name" value="" placeholder="{!! __('tycms.name') !!}" required /> 
  8.        @foreach ($errors->get('name'as $message)  
  9.        <div class="invalid-feedback"
  10.         {{ $message }} 
  11.        </div> 
  12.        @endforeach 
  13.       </div> 
  14.      </div> 
  15.      <div class="form-group"
  16.       <label>{!! __('tycms.password') !!}</label> 
  17.       <div class="input-group"
  18.        <div class="input-group-prepend"
  19.         <span class="input-group-text change-bg">T</span> 
  20.        </div> 
  21.        <input type="password" class="form-control is-invalid" name="password" value="" placeholder="{!! __('tycms.password') !!}" required /> 
  22.        @foreach ($errors->get('password'as $message)  
  23.        <div class="invalid-feedback"
  24.         {{ $message }} 
  25.        </div> 
  26.        @endforeach 
  27.       </div> 
  28.      </div> 
  29.      <div class="form-group"
  30.       <label>{!! __('tycms.confirm_password') !!}</label> 
  31.       <div class="input-group"
  32.        <div class="input-group-prepend"
  33.         <span class="input-group-text change-bg">T</span> 
  34.        </div> 
  35.        <input type="password" class="form-control is-invalid" name="password_confirmation" value="" placeholder="{!! __('tycms.confirm_password') !!}" required /> 
  36.        @foreach ($errors->get('password'as $message)  
  37.        <div class="invalid-feedback"
  38.         {{ $message }} 
  39.        </div> 
  40.        @endforeach 
  41.       </div> 
  42.      </div> 

store

  1. $input_all = $request->all(); 
  2.   $validator = Validator::make($input_all, Manager::rules(), Manager::error_message()); 
  3.   if ($validator->fails())  
  4.   { 
  5.     return redirect() 
  6.           ->action($this->class_basename . '@create'
  7.           ->withErrors($validator
  8.           ->withInput(); 
  9.   } 
  10.   $model = Manager::create($input_all); 

edit.html

  1. <div class="form-group"
  2.       <label>{!! __('tycms.name') !!}</label> 
  3.       <div class="input-group"
  4.        <div class="input-group-prepend"
  5.         <span class="input-group-text change-bg">T</span> 
  6.        </div> 
  7.        <input type="text" class="form-control is-invalid" name="name" value="{{ $model->name }}" readonly="readonly" placeholder="{!! __('tycms.name') !!}" required /> 
  8.        @foreach ($errors->get('name'as $message)  
  9.        <div class="invalid-feedback"
  10.         {{ $message }} 
  11.        </div> 
  12.        @endforeach 
  13.       </div> 
  14.      </div> 
  15.      <div class="form-group"
  16.       <label>{!! __('tycms.old_password') !!}</label> 
  17.       <div class="input-group"
  18.        <div class="input-group-prepend"
  19.         <span class="input-group-text change-bg">T</span> 
  20.        </div> 
  21.        <input type="password" class="form-control is-invalid" name="old_password" value="" placeholder="{!! __('tycms.old_password') !!}" required /> 
  22.        @foreach ($errors->get('old_password'as $message)  
  23.        <div class="invalid-feedback"
  24.         {{ $message }} 
  25.        </div> 
  26.        @endforeach 
  27.       </div> 
  28.      </div> 
  29.      <div class="form-group"
  30.       <label>{!! __('tycms.password') !!}</label> 
  31.       <div class="input-group"
  32.        <div class="input-group-prepend"
  33.         <span class="input-group-text change-bg">T</span> 
  34.        </div> 
  35.        <input type="password" class="form-control is-invalid" name="password" value="" placeholder="{!! __('tycms.password') !!}" required /> 
  36.        @foreach ($errors->get('password'as $message)  
  37.        <div class="invalid-feedback"
  38.         {{ $message }} 
  39.        </div> 
  40.        @endforeach 
  41.       </div> 
  42.      </div> 
  43.      <div class="form-group"
  44.       <label>{!! __('tycms.confirm_password') !!}</label> 
  45.       <div class="input-group"
  46.        <div class="input-group-prepend"
  47.         <span class="input-group-text change-bg">T</span> 
  48.        </div> 
  49.        <input type="password" class="form-control is-invalid" name="password_confirmation" value="" placeholder="{!! __('tycms.confirm_password') !!}" required /> 
  50.        @foreach ($errors->get('password'as $message)  
  51.        <div class="invalid-feedback"
  52.         {{ $message }} 
  53.        </div> 
  54.        @endforeach 
  55.       </div> 
  56.      </div> 

update

  1. $input_all = $request->all(); 
  2.    $model = $this->findById($id); 
  3.    
  4.    $validator = Validator::make($input_all, Manager::rules($id$model), Manager::error_message()); 
  5.    if ($validator->fails())  
  6.    { 
  7.      return redirect() 
  8.            ->action($this->class_basename . '@edit', ['id' => $id]) 
  9.            ->withErrors($validator
  10.            ->withInput(); 
  11.    } 
  12.    $model->fill($input_all); 
  13.    $model->save(); 

Models\Manager

  1. protected $table = 'managers'
  2.    
  3.  protected $fillable = ['name''password']; 
  4.    
  5.  /*public static $rules = [ 
  6.   'name'   => 'required|unique:managers', 
  7.   'password' => 'required|confirmed', 
  8.   'password_confirmation' => 'required|same:password' 
  9.  ];*/ 
  10.    
  11.  public static function rules ($id = null, $manager = null)  
  12.  { 
  13.   if (emptyempty($id)) 
  14.   { 
  15.    $rules = [ 
  16.     'name'   => 'required|unique:managers'
  17.     'password' => 'required|confirmed'
  18.     'password_confirmation' => 'required|same:password' 
  19.    ]; 
  20.   } else 
  21.   { 
  22.    $rules = [ 
  23.     'name'   => [ 
  24.      'required'
  25.      Rule::unique('managers')->ignore($id), 
  26.     ], 
  27.     'old_password' => [ 
  28.      'required'
  29.      function($attribute$value$failuse ($manager)  
  30.      { 
  31.       if (!Hash::check($value$manager->password))  
  32.       { 
  33.        return $fail(__('tyvalidation.old_password')); 
  34.       } 
  35.      }, 
  36.     ], 
  37.     'password' => 'required|confirmed'
  38.     'password_confirmation' => 'required|same:password' 
  39.    ]; 
  40.   } 
  41.   return $rules
  42.  } 
  43.    
  44.  public static function error_message()  
  45.  { 
  46.   return [ 
  47.    'name.required' => __('tyvalidation.name'), 
  48.    'name.unique' => __('tyvalidation.unique'), 
  49.    'password.required' => __('tyvalidation.password'), 
  50.    'password.confirmed' => __('tyvalidation.confirmed'), 
  51.   ]; 
  52.  } 
  53.    
  54.  public function setPasswordAttribute($value
  55.  { 
  56.   $this->attributes['password'] = Hash::make($value); 
  57.  }

Tags: laravel验证 unique验证

分享到: