我在laravel上传时遇到问题。我的观点:
{{ Form::open(array('url'=>'administration/video/create','method' => 'post','files'=>true)) }}
<p>
{{ Form::label('Titlu:') }}
{{ Form::text('title',null,array('class'=>'form-control')) }}
</p>
<p>
{{ Form::label('Description:') }}
{{ Form::text('description',null,array('class'=>'form-control')) }}
</p>
<p>
{{ Form::label('image','Imagine:') }}
{{ Form::file('image','',array('id'=>'','class'=>'')) }}
</p>
<p>
{{ Form::label('video','Video:') }}
{{ Form::file('video','',array('id'=>'','class'=>'')) }}
</p>
{{ Form::submit('Add',array('class'=>'btn btn-primary')) }}
{{ Form::reset('Reset',array('class'=>'btn btn-success')) }}
{{ Form::close() }}
我的控制器:
public function postCreate(){
$video = new \Video();
$video->title = Input::get('title');
$video->description = Input::get('description');
$video->video_image = '';
$video->video_name = '';
if(Input::hasFile('image')) {
$sImagePermalink = \Url_Lib::makePermalink($video->title);
$image = Input::file('image');
$filename = $sImagePermalink . "." . $image->getClientOriginalExtension();
$path = public_path('content/video/' . $filename);
Image::make($image->getRealPath())->resize(468, 249)->save($path);
$video->video_image = 'content/video/' . $filename;
$videoDocument = Input::file('video');
$videofile = $sImagePermalink . "." . $videoDocument->getClientOriginalExtension();
$pathVideo = public_path('content/video/' . $videofile);
Input::file('video')->move('content/video/', $pathVideo);
$video->video_name = 'content/video/' . $videofile;
}
$video->save();
return Redirect::to('/administration/video/add/')
->with('message_succes','Video added');
}
我收到错误:SQLSTATE [23000]:违反完整性约束:1048列&#39;标题&#39;不能为空我不明白为什么?请帮帮我。
答案 0 :(得分:3)
问题是当你创建表/模式时,你没有设置你的标题列可以为空,
您可以通过两种方式解决它。 您可以更改表架构并将标题列设置为可为空,
Schema::create("yourtablename" , function($table){
........
$table->string("title")->nullable();
........
});
或代替Input :: get(“title”)你可以尝试使用默认值,所以即使它是空的或null它将具有默认值。
Input::get("title" , "No title");