如何使用Laravel 5.1在表中保存上传的文件名

dol*_*lar 5 php mysql file-upload laravel laravel-5.1

我需要帮助使用laravel 5.1在数据库表中保存上传的文件名.

我的Controller代码用于保存图像详细信息

public function store(Request $request)
{
   if($request->hasFile('img_filename'))
   {
       $destinationPath="offerimages";
       $file = $request->file('img_filename');
       $filename=$file->getClientOriginalName();
       $request->file('img_filename')->move($destinationPath,$filename);

   }

    $input=$request->all();
    Offer_image::create($input);
    return redirect('offerimage');
}
Run Code Online (Sandbox Code Playgroud)

我的接受图像的视图代码

{!! Form::open(array('route'=>'offerimage.store','role'=>'form','files'=>true)) !!}
              <div class="box-body">

                <div class="form-group">
                  {!! Form::label('img_name','Name') !!}
                  {!! Form::text('img_name', $value = null, $attributes = array('class'=>'form-control','id'=>'img_name','required')) !!}
                </div>

                <div class="form-group">
                  {!! Form::label('img_description','Description') !!}
                  {!! Form::textarea('img_description', $value = null, $attributes = array('class'=>'form-control','id'=>'img_description','required')) !!}
                </div>

                <div class="form-group">
                  {!! Form::label('img_filename','Upload Image') !!}
                  {!! Form::file('img_filename') !!}
                </div>



                {!! Form::hidden('status',$value='active') !!}

              </div><!-- /.box-body -->

              <div class="box-footer">
                {!! Form::submit('Submit',$attributes=array('class'=>'btn btn-primary')) !!}
              </div>
              {!! Form::close() !!}
Run Code Online (Sandbox Code Playgroud)

此控制器代码用于存储图像正常工作,但我试图将图像文件名保存到表中,此代码将文件路径存储到数据库表.

由于我使用直接create()方法将请求对象存储在表中,我不知道如何存储文件名而不是路径.

检查此图像以获取表格数据

dar*_*oup 8

问题是您上传图片时请求数据没有更改.所以img_filename仍然包含tmpdata.

你可以试试这个:

$input = $request->all();
$input['img_filename'] = $filename;
Run Code Online (Sandbox Code Playgroud)