我对传入的POST请求使用以下日期验证。
'trep_txn_date' => 'date_format:"Y-m-d H:i:s.u"'
这只允许这种日期,即2012-01-21 15:59:44.8
我还想在没有TIME的情况下允许日期,例如2012-01-21,当发送到mysql db时会自动存储为2012-01-21 00:00:00.0
有没有办法可以使用Laravel现有的验证规则来实现这一点。 有没有办法在date_format规则中定义多种格式,如下所示。
'trep_txn_date' => 'date_format:"Y-m-d H:i:s.u","Y-m-d"' //btw this didn't work.
谢谢,
ķ
答案 0 :(得分:24)
date_format 验证程序仅采用一种日期格式作为参数。为了能够使用多种格式,您需要构建自定义验证规则。幸运的是,这很简单。
您可以使用以下代码在 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;
});
}
}
您可以稍后使用此新的验证规则:
'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