LARAVEL - Displaying images from the storage folder

生来就可爱ヽ(ⅴ<●) 提交于 2019-12-23 21:45:10

问题


I'm new to Laravel and was wondering if someone can help me out with a simple image upload.

I have a form that allows a user to create a profile and upload and avatar for their profile during the process. This all works perfectly. Here is the code from my controller:

if (request()->hasFile('avatar')) {

        $file = request()->file('avatar');

        $file->storeAs('avatars/' . auth()->id(), 'avatar.jpg');
    }

The image is saved within storage/app/avatars/USER-ID/avatar.jpg

I'm not sure how to display the image from this folder. I've looked for solutions but I am unable to use php artisan storage:link as it is not my server. How do I go about this without using the storage link? Can I create a link manually?

If someone could explain a solution to me that would be perfect!

Just ask if you need any code snippets.

Thanks!


回答1:


You will need to access the protected files using a route the plugs into a controller that can access the files and pass it to the view.

I would also recommend using the package intervention/image it can be installed by

composer require intervention/image

See below to on accessing the image:

// Your route in web.php

// Public route to show user avatar
Route::get('avatars/{id}/{image}', [
    'uses'      => 'TheNameOfYourController@userProfileAvatar'
]);

// In your controller file. In this example according the name of what we have above it would be userProfileAvatar()

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Image;

class TheNameOfYourController extends Controller
{

    /**
     * Show user avatar
     *
     * @param $id
     * @param $image
     * @return string
     */
    public function userProfileAvatar($id, $image)
    {
        return Image::make(storage_path() . '/avatars/' . $id . '/' . $image)->response();
    }

}

// Your blade view to display the image

<img src="images/profile/{{ \Auth::user()->id }}/avatar.jpg" alt="{{ \Auth::user()->name }}">

Here are some references but this intances that go one step further and save the file path the database upon upload:

// Route Example

  • https://github.com/jeremykenedy/laravel-auth/blob/master/routes/web.php

// Controller Example

  • https://github.com/jeremykenedy/laravel-auth/blob/master/app/Http/Controllers/ProfilesController.php

// View Examples

  • https://github.com/jeremykenedy/laravel-auth/blob/master/resources/views/profiles/show.blade.php

  • https://github.com/jeremykenedy/laravel-auth/blob/master/resources/views/profiles/edit.blade.php

  • https://github.com/jeremykenedy/laravel-auth/blob/master/resources/views/partials/nav.blade.php




回答2:


Well if you don't have access to the server to create a symlink, you need to create a route that returns the image as response.

Something like that:

Route::get('storage/{filename}', function ($filename) 
{
   $path = storage_path('avatars/' . $filename);

   if (!File::exists($path)) {
      abort(404);
   }

   $file = File::get($path);
   $type = File::mimeType($path);

   $response = Response::make($file, 200);
   $response->header("Content-Type", $type);

   return $response;
});



回答3:


Create a symbolic link which will connect storage/app and public/img directories, for example:

ln -s /home/laravel/public/img /home/laravel/storage/app

Then just use asset() helper to generate a link:

<img src="{{ asset('img/avatars/'.auth()->id().'/avatar.jpg') }}">


来源:https://stackoverflow.com/questions/43296197/laravel-displaying-images-from-the-storage-folder

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!