Laravel 5.1 date_format validation allow two formats
我将以下日期验证用于传入的POST请求。
1 | 'trep_txn_date' => 'date_format:"Y-m-d H:i:s.u"' |
这将只允许这种日期,即2012-01-21 15:59:44.8
我也想允许没有时间的日期,例如 2012-01-21,当发送到mysql db时,它将自动存储为2012-01-21 00:00:00.0
有没有一种方法可以使用Laravel的现有验证规则来做到这一点。
有没有一种方法可以在date_format规则中定义多种格式,如下所示。
1 | 'trep_txn_date' => 'date_format:"Y-m-d H:i:s.u","Y-m-d"' //btw this didn't work. |
谢谢,
?
date_format验证器仅采用一种日期格式作为参数。 为了能够使用多种格式,您需要构建自定义验证规则。 幸运的是,这非常简单。
您可以使用以下代码在AppServiceProvider中定义多格式日期验证:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | 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; }); } } |
您以后可以像这样使用此新的验证规则:
1 | 'trep_txn_date' => 'date_multi_format:"Y-m-d H:i:s.u","Y-m-d"' |
您可以在此处阅读有关如何创建自定义验证规则的更多信息:http://laravel.com/docs/5.1/validation#custom-validation-rules