欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關于Laravel參數驗證的一些疑與惑

 更新時間:2019年11月19日 08:31:10   作者:寫PHP的老王  
這篇文章主要給大家介紹了關于Laravel參數驗證的一些疑與惑,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Laravel具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

驗證器怎么創(chuàng)建的,誰創(chuàng)建的

Laravel 文檔調用驗證器,除了通過控制器,還有就是通過Facades的方式創(chuàng)建驗證器對象。Validator::make($data,$rule,$message)。

config/app.php 中注冊了'Validator' => Illuminate\Support\Facades\Validator::class。

<?php

namespace Illuminate\Support\Facades;

/**
 * @see \Illuminate\Validation\Factory
 */
class Validator extends Facade
{
  /**
   * Get the registered name of the component.
   *
   * @return string
   */
  protected static function getFacadeAccessor()
  {
    return 'validator';
  }
}

從上面可以看出,Validator的實際實現(xiàn)類是容器中的validator對象,那這個validator對象是哪個?

<?php

namespace Illuminate\Foundation;
...
class Application extends Container implements ApplicationContract, HttpKernelInterface
{
  ...
  public function registerCoreContainerAliases()
  {
    foreach ([
      ...
      'validator'=> [
        \Illuminate\Validation\Factory::class,
        \Illuminate\Contracts\Validation\Factory::class
      ],
    ])
    ...
  }
  ...
}

可以看出,最終創(chuàng)建驗證器是通過實現(xiàn)\Illuminate\Contracts\Validation\Factory接口的\Illuminate\Validation\Factory類創(chuàng)建的。再來看看,這個工廠類怎么創(chuàng)建實際的驗證器的。

//\Illuminate\Contracts\Validation\Factory 源碼

protected function resolve(array $data, array $rules, array $messages, array $customAttributes)
{
  if (is_null($this->resolver)) {
    return new Validator(
      $this->translator,
      $data,
      $rules,
      $messages,
      $customAttributes
    );
  }

  return call_user_func(
    $this->resolver,
    $this->translator,
    $data,
    $rules,
    $messages,
    $customAttributes
  );
}

到這里,可以看出Laravel的驗證器的創(chuàng)建都是通過特定的工廠類創(chuàng)建。

如果需要自定義驗證器類(比如我需要把5.8的一些新功能遷移到5.5的版本上),有兩種方式:

一,創(chuàng)建一個自定義的工廠類。然后在AppServiceProvider中重新綁定新的驗證器工廠創(chuàng)建類;

二,AppServiceProvider中通過resolver方法設置工廠類的resolver屬性,接管驗證器的實例化,例如:

Validator::resolver(function($translator, $data, $rules, $messages, $customAttributes){
  return new ExtendValidator($translator, $data, $rules, $messages, $customAttributes);
});

如何自定義驗證規(guī)則

Laravel本身提供了很多通用的參數驗證規(guī)則,但是對于一些特定的場景,還是需要提供驗證規(guī)則的擴展。

Laravel驗證規(guī)則的擴展有兩種方式。

1 通過extend方法擴展

//這是一個簡單的參數比較的驗證規(guī)則,Laravel5.8中提供,Laravel5.5中未提供
//驗證規(guī)則如下: 'max_num'=>'gte:min',
Validator::extend('gte',function($attribute, $value, $parameters, $validator){
  if($value>=data_get($validator->getData(),$parameters[0]))
  {
    return true;
  }
  return false;
});
//\Illuminate\Contracts\Validation\Factory 源碼
public function extend($rule, $extension, $message = null)
{
  $this->extensions[$rule] = $extension;

  if ($message) {
    $this->fallbackMessages[Str::snake($rule)] = $message;
  }
}
//\Illuminate\Validation\Validator 源碼
protected function callExtension($rule, $parameters)
{
  $callback = $this->extensions[$rule];

  if (is_callable($callback)) {
    return call_user_func_array($callback, $parameters);
  } elseif (is_string($callback)) {
    return $this->callClassBasedExtension($callback, $parameters);
  }
}

protected function validateAttribute($attribute, $rule)
{
  ...
  $method = "validate{$rule}";
  if ($validatable && ! $this->$method($attribute, $value, $parameters, $this)) {
    $this->addFailure($attribute, $rule, $parameters);
  }
}

public function __call($method, $parameters)
{
  $rule = Str::snake(substr($method, 8));

  if (isset($this->extensions[$rule])) {
    return $this->callExtension($rule, $parameters);
  }

  throw new BadMethodCallException(sprintf(
    'Method %s::%s does not exist.', static::class, $method
  ));
}

Factory提供了extend方法用于擴展規(guī)則驗證方法。所有的擴展規(guī)則最終都會被傳到驗證器中。驗證器在驗證參數的過程中,如果找到匹配的驗證規(guī)則,則直接進行驗證。否則調用魔術方法__call查找擴展驗證函數。擴展函數返回布爾值,返回true則表示驗證通過,返回false表示驗證失敗。

2 通過自定義規(guī)則類擴展

Laravel 中提供了Illuminate\Contracts\Validation\Rule接口,只有實現(xiàn)了這個接口的類都認為是符合的自定義驗證規(guī)則類。

<?php

namespace Illuminate\Contracts\Validation;

interface Rule
{
  /**
   * Determine if the validation rule passes.
   *
   * @param string $attribute
   * @param mixed $value
   * @return bool
   */
  public function passes($attribute, $value);

  /**
   * Get the validation error message.
   *
   * @return string
   */
  public function message();
}

自定義規(guī)則類需要實現(xiàn)的方法有passes方法,用于驗證參數是否合法。message方法,用于提供驗證失敗的錯誤提示信息。

使用自定義驗證類,相對于extend方法擴展有一個很大的bug就是無法在自定義類中獲取到當期的驗證器對象。從而導致在當前擴展的驗證規(guī)則中,只能過獲取到需要驗證的數據,而獲取不到其他的字段數據,無法進行聯(lián)合字段的驗證。像上面比較兩個字段的大小的驗證規(guī)則就無法實現(xiàn)。

如果想要通過自定義驗證規(guī)則類實現(xiàn)上面兩個字段大小比較的驗證規(guī)則,則需要自定義驗證類,修改validateUsingCustomRule方法,將當期驗證器傳入到自定義驗證規(guī)則實例對象中去。

protected function validateUsingCustomRule($attribute, $value, $rule)
{
  if(method_exists($rule, 'setValidator'))
  {
    $rule->setValidator($this);
  }
  return parent::validateUsingCustomRule($attribute,$value,$rule);
}

如何實現(xiàn)用當期類方法作為驗證規(guī)則驗證函數

像Yii2中,因為基本上所有的對象都有驗證方法,所以很容易用當期類方法作為驗證規(guī)則驗證函數。

例如,一個驗證規(guī)則如下,表示用當期類的validateMinNum對參數進行驗證,那么,這樣的一個功能,如何在Laravel中實現(xiàn)呢。

['min_num'=>'validateMinNum']

方法1 通過自定義類實現(xiàn) Laravel提供了ClosureValidationRule自定義驗證類,用來添加回調函數的驗證。

例如

$rule = [
  'min'=>new ClosureValidationRule([$this,'checkv'])
];
$data = ['min'=>10];
$v = Validator::make($data,$rule);

方法2 通過extend方式實現(xiàn)

$rule = [
  'min'=>'checkv'
];
Validator::extend('checkv',[$this,'checkv']);

但是這種方式對驗證器的影響是全局的。不建議使用。

總結

通過以上源碼的學習,可以看出Laravel驗證器的創(chuàng)建都是用過驗證器工廠類創(chuàng)建的。如果需要自定義驗證器,可以通過修改驗證器工廠類,或者設置驗證器工廠類的resolver屬性接管驗證器的實例化。

驗證規(guī)則的擴展有兩種方式,一種是通過extend方式實現(xiàn)。extend方式對驗證器的影響是全局的,整個運行進程有效??梢垣@取到驗證器本身,因此可以做多個字段關系的驗證;另一種是通過自定義規(guī)則類實現(xiàn)。自定義規(guī)則了只對使用自定義規(guī)則類的驗證有效。但是自定義規(guī)則類本身無法直接獲取到驗證器本身,不能夠做多個字段關系的驗證。如果需要實現(xiàn),則需要使用自定義驗證器,將驗證器傳入到驗證規(guī)則中去。

Laravel本身提供了ClosureValidationRule的驗證規(guī)則用于處理回調函數驗證規(guī)則。同時也可以使用extend方式進行回調函數的驗證。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

相關文章

  • Laravel中encrypt和decrypt的實現(xiàn)方法

    Laravel中encrypt和decrypt的實現(xiàn)方法

    這篇文章主要給大家介紹了關于Laravel中encrypt和decrypt的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-09-09
  • PHP實現(xiàn)微信申請退款流程實例代碼

    PHP實現(xiàn)微信申請退款流程實例代碼

    本篇文章給大家介紹php實現(xiàn)微信申請退款流程,使用到官方提供的SDK中的最重要的一個類文件WxPay.Api.php中提供的refund()方法來實現(xiàn)的,完整大家大家參考下本文
    2018-03-03
  • Thinkphp 框架擴展之驅動擴展實例分析

    Thinkphp 框架擴展之驅動擴展實例分析

    這篇文章主要介紹了Thinkphp 框架擴展之驅動擴展,結合實例形式分析了Thinkphp 框架驅動擴展相關原理、實現(xiàn)方法及操作注意事項,需要的朋友可以參考下
    2020-04-04
  • Laravel實現(xiàn)用戶多字段認證的解決方法

    Laravel實現(xiàn)用戶多字段認證的解決方法

    最近在工作中遇到一個問題,需要多字段的驗證,通過查找相關資料終于解決了,下面這篇文章主要給大家介紹了關于Laravel如何實現(xiàn)用戶多字段認證的解決方法,文中通過示例代碼介紹的非常詳細,需要的朋友們可以參考借鑒,下面來一起看看吧。
    2017-09-09
  • php使用filter過濾器驗證郵箱 ipv6地址 url驗證

    php使用filter過濾器驗證郵箱 ipv6地址 url驗證

    原來判斷郵箱、url和ip地址格式是否符合都是用正則表達式。后來才知道在php中也可以使用內置的函數庫filter來完成這些功能,下面分享給大家
    2013-12-12
  • php獲取訪問者IP地址匯總

    php獲取訪問者IP地址匯總

    在很我的時候我們需要得到用戶的真實IP地址,例如,日志記錄,地理定位,將用戶信息,網站數據分析等,其實獲取IP地址很簡單$_SERVER[\'REMOTE_ADDR\']就可以了。下面我們就來給大家匯總一下常用的幾種獲取IP地址的方法。
    2015-04-04
  • thinkPHP3.2.3實現(xiàn)阿里大于短信驗證的方法

    thinkPHP3.2.3實現(xiàn)阿里大于短信驗證的方法

    這篇文章主要介紹了thinkPHP3.2.3實現(xiàn)阿里大于短信驗證的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-06-06
  • php實現(xiàn)搜索類封裝示例

    php實現(xiàn)搜索類封裝示例

    這篇文章主要為大家詳細介紹了php實現(xiàn)搜索類封裝示例,感興趣的小伙伴們可以參考一下
    2016-03-03
  • PHP之正則表達式捕獲組與非捕獲組(詳解)

    PHP之正則表達式捕獲組與非捕獲組(詳解)

    這篇文章主要介紹了php之正則表達式捕獲組與非捕獲組的詳細介紹,需要的朋友可以參考下
    2015-07-07
  • ThinkPHP使用Smarty第三方插件方法小結

    ThinkPHP使用Smarty第三方插件方法小結

    這篇文章主要介紹了ThinkPHP使用Smarty第三方插件方法,結合實例形式總結分析了ThinkPHP使用Smarty模板的具體步驟與相關注意事項,需要的朋友可以參考下
    2016-03-03

最新評論