我对接收的POST请求使用以下日期验证.
'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规则中定义多个格式,如下所示.
'trep_txn_date' => 'date_format:"Y-m-d H:i:s.u","Y-m-d"' //btw this didn't work.
谢谢,
ķ
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