0
在提交的文件我有这个以下错误:Laravel 5.1:不能上传视频文件
SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'video_ogg' cannot be null (SQL: insert into `profiles` (`about_me`, `video_ogg`, `updated_at`, `created_at`) values (lorem, , 2017-07-23 02:15:50, 2017-07-23 02:15:50))
其中规定,外地video_ogg cannot be null
但是当我在调试模式下,该字段不为空验证(见下文)
控制器
public function store(Request $request)
{
// Validation //
$validation = Validator::make($request->all(), [
'about_me' => 'required',
'video_ogg' => 'required|mimes:mp4,ogx,oga,ogv,ogg,webm|min:1|max:3240',
]);
// Check if it fails //
if($validation->fails()){
return redirect()->back()->withInput()
->with('errors', $validation->errors());
}
$profile = new Profile;
//Debugging
dd($request->files);
// save media data into database //
$profile->about_me = $request->input('about_me');
$profile->video_ogg = $request->input('video_ogg');
$profile->save();
return redirect('/profile')->with('message','You just created your profile!');
}
调试结果
FileBag {#45 ▼
#parameters: array:1 [▼
"video_ogg" => UploadedFile {#30 ▼
-test: false
-originalName: "mov_bbb.ogg"
-mimeType: "audio/ogg"
-size: 614492
-error: 0
}
]
}
在这里,你可以看到调试上传的视频或我的意思是在请求数组,但我仍然有一个错误消息。
SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'video_ogg' cannot be null (SQL: insert into `profiles` (`about_me`, `video_ogg`, `updated_at`, `created_at`) values (lorem, , 2017-07-23 02:15:50, 2017-07-23 02:15:50))
视图
{!! Form::open(['url'=>'/profile', 'method'=>'POST', 'files'=>'true']) !!}
...
<div class="form-group">
<label for="video_ogg">Upload Video (ogg)</label>
<input type="file" class="form-control" name="video_ogg">
</div>
...
这
<form method="POST" action="http://localhost:8000/profile" accept-charset="UTF-8" enctype="multipart/form-data"><input name="_token" type="hidden" value="KxvK6tONoUhBCx58ESlbE1hh9eP8hy5nQyNqb62W">
所以,我没有验证其输出enctype="multipart/form-data"
是形式。
模型
class Profile extends Model
{
//
protected $fillable = ['video_ogg', 'about_me'];
}
你有没有设置'video_ogg'是你的模型可填写? –
你可以试试'dd($ request-> input('video_ogg'))'并发布结果吗? –
@VandolphReyes它是空的 –