Javed
Javed

Reputation: 857

laravel : How to Store file uploaded path in database

Here is my controller code :

 public function save(Request $request) {
    try {

        $this->validate($request, Country::rules());


        If(Input::hasFile('flag_image')){
            $file = Input::file('flag_image');
            $destinationPath = public_path(). '/images/admin/country/';
            $filename = $file->getClientOriginalName();
            $image = time().$filename;
            $file->move($destinationPath, $image);
            $imgpath = 'public/images/admin/country/'.$image;
        }
        $request['flag_image'] = $imgpath;
        $country = Country::saveOrUpdate($request);
        if($country !== false) {
            return redirect()->route('lists-country')->with('success', trans('Country data added successfully.!!'));
        } else {
            return back()->with('error', "Unable to save country data.!!")->withInput();
        }
    } catch (\Exception $ex) {
        return back()->with('error', "Unable to save country data.!!")->withInput();
    }
}

When I dd($request) before saveOrUpdate function I got the full path of the image uploaded file.

 +request: ParameterBag {#40 ▼
#parameters: array:6 [▼
  "_token" => "c94UG3R2PbbdHsXRLzs9OjEBTna23OHINFpki63U"
  "id" => ""
  "title" => "INDIA"
  "short_name" => "IN"
  "status" => "Active"
  "flag_image" => "public/images/admin/country/1515577652banner5.jpg"
]}

After successfully adding data on table a flag_image path look like "D:\xampp\tmp\php63D3.tmp" i want to store "public/images/admin/country/1515577652banner5.jpg" this path.

Upvotes: 1

Views: 5159

Answers (2)

Alexey Mezenin
Alexey Mezenin

Reputation: 163748

You need to merge() it:

$request->merge(['flag_image' => $imgpath]);

Instead of:

$request['flag_image'] = $imgpath;

Upvotes: 2

BM2ilabs
BM2ilabs

Reputation: 532

Just do

$country->flag_image = $imgpath;
$country->save();

after

$country = Country::saveOrUpdate($request);

Upvotes: 3

Related Questions