Hello i'm working on laravel project , so in the part of admin voyager , the pictures in the folder public/assets/img don't appear in the tables ,
Some pictures appear and other not .
any help how to solve this problem ?
this is the filesystems.php
'public' => [
'driver' => 'local',
'root' => storage_path('app/public'),
'url' => env('APP_URL').'/storage',
'visibility' => 'public',
I had to change the line starting with url to
'url' => env('APP_URL').'/nameofmyrootfolder/storage/app/public',
This allowed the link to the images to be resolved.
Related
voyager project is installed on a subdomaine. https://sub.domainname.com/ ,
There is no problem in uploading images in local and I can show them But when i try it on hosting, the pictures appear broken, no matter what i did
APP URL
APP_URL=https://sub.domainname.com
Config/fileSystems
'disks' => [
'local' => [
'driver' => 'local',
'root' => storage_path('app'),
],
'public' => [
'driver' => 'local',
'root' => storage_path('app/public'),
'url' => env('APP_URL').'/storage',
'visibility' => 'public',
],
's3' => [
'driver' => 's3',
'key' => env('AWS_ACCESS_KEY_ID'),
'secret' => env('AWS_SECRET_ACCESS_KEY'),
'region' => env('AWS_DEFAULT_REGION'),
'bucket' => env('AWS_BUCKET'),
'url' => env('AWS_URL'),
'endpoint' => env('AWS_ENDPOINT'),
'use_path_style_endpoint' => env('AWS_USE_PATH_STYLE_ENDPOINT', false),
],
],
after uploading an image its image on the media menu
enter image description here
Did you publish the storage folder link? php artisan storage:link
Sorry, but is all your code inside the public_html folder? I mean, is there all including routes, storage, app, etc.?
This may affect the way your application considers where is the public folder. So you can open Tinker or add a log to see if the public_path() function is returning the correct path. If not, then you should instruct your application to redirect the path to the right folder or change the structure of your project to one more convenient/secure.
Also is the one from the example the subdomain? As it looks like a main domain.
PS: I don't know much about the cons, but most people doesn't recommend exposing paths here, like your project's domain or structure, as you don't know what can people do with that information.
Update Question
I'm uploading from my subdomain project to the storage folder in the root directory
this way I created a voyager storage in
'voyager' => [
'driver' => 'local',
'root' => '/home/username/public_html/storage/app/public',
'url' => 'https://website.com/storage',
'visibility' => 'public',
]
In my config/voyager.php file, I gave the disk I created custom.
'storage' => [
'disk' => 'voyager',
],
In this way, I can send images to the root directory of the project under public_html, but my images are still not visible on voyager.
The path of the images looks like this;
https://website.com/storage/works/July2022/5w9ONuhB1VgQFLj9hGJH.png
I'm trying to create a Dashboard for a personal project,
I want the storage of the Dashboard to be completely separate from the front end,
I create a new disk in the filesystem.php and this is the details:
'disks' => [
'local' => [
'driver' => 'local',
'root' => storage_path('app'),
],
'public' => [
'driver' => 'local',
'root' => storage_path('app/public'),
'url' => env('APP_URL').'/storage',
'visibility' => 'public',
],
'backend' => [
'driver' => 'local',
'root' => storage_path('app/backend'),
'visibility' => 'public',
],
's3' => [
'driver' => 's3',
'key' => env('AWS_ACCESS_KEY_ID'),
'secret' => env('AWS_SECRET_ACCESS_KEY'),
'region' => env('AWS_DEFAULT_REGION'),
'bucket' => env('AWS_BUCKET'),
'url' => env('AWS_URL'),
'endpoint' => env('AWS_ENDPOINT'),
],
],
after that, I try to store some avatars and it works perfectly,
my problem is when I want to access the files from the view side,
Note that I try the visibility on both public and private
,also
I want to store sensitive files inside it
so I try:
url('/storage/avatars/filename.png'),
storage_path('backend/avatars/filename.png'),
storage::disk('backend')->get('avatars/filename.png'),
but nothing.
What is your question exactly? I assume you are trying to display images on a webpage, but they are not showing up?
This has to do with the visibility of your files. Only files in the storage/app/public directory are available for display. So images that should be visible using a URL, should be stored in that directory.
The best practice here is to upload the image to the Public disk. Make sure to create the symoblic link using php artisan storage:link.
For any other non-public file, you can set-up a Controller to return a download response
Another option is to display content right away in the browser, like a PDF. In that case, you should set the correct Content-Type while returning the response, with the contents of the PDF.
If this did not answer your question, please let me know.
please tell me. My version is Laravel 5.2.
config/filesystems.php configuration:
'local' => [
'driver' => 'local',
'root' => storage_path('app'),
],
'public' => [
'driver' => 'local',
'root' => storage_path('app/public'),
'visibility' => 'public',
],
If I save the file this way:
Storage::disk('local')->put('token/token.json', json_encode($data));
Will users be able to access it? I just need to keep the token in a safe place so that no one can access it. Thank you in advance for your response
I need to display in blade the videos uploaded in storage/videos and i don't know how to do.
For uploading them in storage i put this code in filesystems.php
'public' => [
'driver' => 'local',
'root' => storage_path('app/public'),
'url' => env('APP_URL').'/storage',
'visibility' => 'public',
],
'video' => [
'driver' => 'local',
'root' => storage_path(),
'url' => env('APP_URL').'storage/video',
'visibility' => 'public',
],
I tried many combinations for the path but anyone doesnt's work
url/storage/video/VHqPwguZeM6mf4csBTfj.mp4
or
url/storage/VHqPwguZeM6mf4csBTfj.mp4
or
url/video/VHqPwguZeM6mf4csBTfj.mp4
Can anyone help me?
Thanks!
The solution is easy once you have uploaded the video in storage/videos you have to do two steps:
php artisan storage:link
this command links your public folder with storage after that you can find a shortcut of storage folder in your public folder.
2.In your blade file just do this:
I've a question, how can change filepath in laravel?
this is my code on under.
'public' => [
'driver' => 'local',
'root' => storage_path('app/public'),
'url' => env('APP_URL').'/storage',
'visibility' => 'public',
now, when I upload the file, it will saved to /storage/app/public/images
123.com/storage/app/public/images
how can change filepath to /public/storage/images
123.com/public/storage/images