Laravel日期格式验证dd / mm / yyyy

时间:2018-05-18 10:05:20

标签: validation date laravel-5 format

一件简单的事,请帮帮我。我想验证日期格式(dd / mm / yyyy)。 如果我的输入是05/02/1991或5/2/1991,则应返回 ' true' ,但

 public function rules()
  {
    return [
        'date_of_birth'         => 'required|date_format:"d/m/Y"'
    ];
  }

在上述规则中,仅针对 05/02/1991 返回 true 。我需要匹配它们。

3 个答案:

答案 0 :(得分:1)

您可以合并dateregex来处理,因为date_format只能处理一种格式:

<?php

public function rules()
{
    return [
        'date_of_birth' => 'required|date|regex:/\d{1,2}\/\d{1,2}\/\d{4}/'
    ];
}

答案 1 :(得分:0)

date验证程序只使用一种日期格式作为参数。为了能够使用多种格式,您需要构建自定义验证规则。这很简单。能够在单个验证器中使用多种日期格式您可以使用以下代码在AppServiceProvider中定义多格式日期验证:

class AppServiceProvider extends ServiceProvider  
{
 public function boot()
 {
    Validator::extend('date_multi_format', function($attribute, $value, $formats) {
        // iterate through all formats
        foreach($formats as $format) {

            // parse date with current format
            $parsed = date_parse_from_format($format, $value);

            // if value matches given format return true=validation succeeded 
            if ($parsed['error_count'] === 0 && $parsed['warning_count'] === 0) {
              return true;
            }
          }

     // value did not match any of the provided formats, so return false=validation failed
     return false;
    });
  }
}

您可以稍后使用此新的验证规则:

'date' => 'date_multi_format:"Y-m-d H:i:s.u","Y-m-d"' //or any other format

希望这有帮助

答案 2 :(得分:0)

我遇到了类似的问题,其中一些表单使用时间选择器,而其他表单使用 <input type="time">。后者格式为 24 小时制,与浏览器中使用的格式无关。

继@Foysal 的回答之后,您现在还可以创建一个 Rule 对象来定义您的规则,而不必扩展验证器。

@see https://laravel.com/docs/8.x/validation#using-rule-objects

运行php artisan make:rule DateMultiFormat

然后在位于 app/Rules 的新规则对象中,您可以添加相同的逻辑。

在构造函数中接受可接受的格式,然后在 passes() 方法中添加逻辑。

foreach ($this->acceptedFormats as $format) {
    $parsed = date_parse_from_format($format, $value);
    
    if ($parsed['error_count'] === 0 && $parsed['warning_count'] === 0) {
        return true;
    }
}
        
return false;

在你的验证器类中...

public function rules()
{
    return [
        'date' => [
            'required', // or whatever
            new DateMultiFormat(['m/d/Y', 'Y-m-d']),
        ],
        ...
    ];

对于我的用例,在准备表单输入以保留在数据库中时,我还必须允许这两种格式。

try {
    $start = Carbon::createFromFormat('m/d/Y g:i A', $startString, $locationTimeZone);
} catch (InvalidFormatException $e) {
    $start = Carbon::createFromFormat('m/d/Y H:i', $startString, $locationTimeZone);
}