php 我无法解决Laravel图像存储和显示的问题

cuxqih21  于 2024-01-05  发布在  PHP
关注(0)|答案(1)|浏览(171)

我已经使用Laravel几个月了,我认为我已经很好地掌握了它。最近,我正在为自己建立一个投资组合网站,我想让它从我的数据库中获取数据,并在一个“项目”页面中显示一大堆数据。在我换电脑之前,它一直工作得很好(从台式机到工作专用笔记本电脑)我转移了我的应用程序文件,以便我可以在笔记本电脑设置后立即继续使用它,它似乎工作正常,但我现在面临着一个我无法调试的问题。
虽然我的页面显示项目正确地从数据库中获取数据,但每个项目的图像并没有显示。相反,我得到了一个小图标,当图像被破坏时(白色和绿色)
当我说我不能调试它为我的生活,这里是我遵循的步骤:
初始图像存储来自将其注册到数据库中的函数

  1. public function storeProject(Request $request)
  2. {
  3. //dd($request->all());
  4. // Valider les données du formulaire
  5. $validatedData = $request->validate([
  6. 'name' => 'required|string|max:191',
  7. 'image_1' => 'required|file|image|mimes:jpg,jpeg,png|max:4000',
  8. 'description' => 'required|string',
  9. 'url' => 'required|url',
  10. 'customer' => 'required|string|max:191',
  11. 'mission' => 'required|string|max:191',
  12. 'tags' => 'nullable|array',
  13. ]);
  14. //dd($validatedData);
  15. // convert string to array
  16. $mission = $validatedData['mission'] ? [$validatedData['mission']] : [];
  17. //Enregistrer les image sur notre serveur
  18. $imagePaths = [];
  19. $images = [$request->file('image_1'), $request->file('image_2'), $request->file('image_3')];
  20. foreach ($images as $image) {
  21. if ($image) {
  22. $filename = time() . '-' . $image->getClientOriginalName();
  23. $path = $image->storeAs('public/images/' . $filename);
  24. $imagePaths[] = $filename;
  25. }
  26. }
  27. // Nouveau projet avec les données validées du formulaire
  28. $project = new projet;
  29. $project->name = $validatedData['name'];
  30. $project->image_1 = $imagePaths[0] ?? null;
  31. $project->description = $validatedData['description'];
  32. $project->url = $validatedData['url'];
  33. $project->customer = $validatedData['customer'];
  34. $project->mission = $validatedData['mission'];
  35. $project->user_id = Auth::user()->id;
  36. $project->save();
  37. // tags
  38. $tags = $validatedData['tags'];
  39. $project->addtags($tags);
  40. // categories
  41. $project->addCategory($mission);
  42. return redirect()->route('moderate')->with('success', 'Projet mis en Ligne avec succès.');
  43. // redirection avec errors
  44. }

字符串
这个函数可以工作,数据库正确地注册数据,并且在刀片视图获取数据时正确地显示数据(减去图像)。

  1. @extends('layouts.app')
  2. @section('title', 'Portfolio')
  3. @section('content')
  4. <div class="containers">
  5. <div class="mobilemenubar">
  6. </div>
  7. <div class="column">
  8. <div class="BackgroundImage">
  9. <img src="{{ Storage::url('/images/Homeimage.jpg') }}" alt="Background-Image" />
  10. <div class="project-container">
  11. {{-- We use the Modulo operator here : passing projects to the view in an array, we check the array's index with the modulo operator to see if the index is dividable by 2, if so we give it a value of 0 if not a value of 1, then use an odd/even system to alternate layouts --}}
  12. <div class="addbutton">
  13. <a href="{{ route('add-project') }}">Ajouter un nouveau Projet</a>
  14. </div>
  15. @foreach ($projects as $index => $project)
  16. @if ($index % 2 === 0)
  17. <div class="project-first-layout">
  18. <div class="first-layout-image-box"> <img
  19. src="{{ asset('storage/images/' . $project->image_1) }}" alt="{{ $project->name }}">
  20. </div>
  21. <div class="first-layout-text-area"> {{ $project->description }} </div>
  22. <div class="externals">
  23. <a href="{{ $project->url }}" class="external-link">Visiter le Site</a>
  24. <a href="#" class="external-link">Git</a>
  25. </div>
  26. <div class="buttons">
  27. <form action=" {{ route('edit-project', $project->id) }}" method="GET">
  28. @csrf
  29. <button type="submit">Modifier</button>
  30. </form>
  31. <form action=" {{ route('delete-project', $project->id) }}"class="Delete"
  32. method="POST">
  33. @csrf
  34. @method('DELETE')
  35. <button type="submit">Supprimer</button>
  36. </form>
  37. </div>
  38. </div>
  39. @else
  40. <div class="project-second-layout">
  41. <div class="second-layout-image-box"><img
  42. src="{{ asset('storage/images/' . $project->image_1) }}" alt="{{ $project->name }}">
  43. </div>
  44. <div class="second-layout-text-area">{{ $project->description }}</div>
  45. <div class="externals">
  46. <a href="{{ $project->url }}" class="external-link">Visiter le Site</a>
  47. <a href="#" class="external-link">Git</a>
  48. </div>
  49. <div class="buttons">
  50. <form action=" {{ route('edit-project', $project->id) }}" method="GET">
  51. @csrf
  52. <button type="submit">Modifier</button>
  53. </form>
  54. <form action=" {{ route('delete-project', $project->id) }}"class="Delete"
  55. method="POST">
  56. @csrf
  57. @method('DELETE')
  58. <button type="submit">Supprimer</button>
  59. </form>
  60. </div>
  61. </div>
  62. @endif
  63. @endforeach
  64. </div>
  65. <div class="Navbuttons">
  66. <div class="AdminWelcomeBox">
  67. <h1>Mes Projets</h1>
  68. </div>
  69. @include('components.admin-navmenu')
  70. <div id="adminsocials">
  71. <a href="#"><i class="fa-brands fa-facebook fa-4x" id="Facebook"></i></a>
  72. <a href="#"><i class="fa-brands fa-twitter fa-4x" id="Twitter"></i></a>
  73. <a href="#"><i class="fa-brands fa-linkedin fa-4x" id="Linkedin"></i></a>
  74. </div>
  75. </div>
  76. </div>
  77. </div>
  78. @endsection


在这种情况下,错误来自first-layout-image-box和second-layout-image-box,它们没有正确返回图像(而HomeImage显示正确)

  • 我试过了using Storage::url helper,using asset()helper,using just url()helper,and none of these worked. -我确保我的php artisan storage:link设置好了,它是-我已经清除了缓存
    这是我的文件系统设置:
  1. 'disks' => [
  2. 'local' => [
  3. 'driver' => 'local',
  4. 'root' => storage_path('app'),
  5. 'throw' => false,
  6. ],
  7. 'public' => [
  8. 'driver' => 'local',
  9. 'root' => storage_path('app/public'),
  10. 'url' => env('APP_URL').'/storage',
  11. 'visibility' => 'public',
  12. 'throw' => false,
  13. ],
  14. 's3' => [
  15. 'driver' => 's3',
  16. 'key' => env('AWS_ACCESS_KEY_ID'),
  17. 'secret' => env('AWS_SECRET_ACCESS_KEY'),
  18. 'region' => env('AWS_DEFAULT_REGION'),
  19. 'bucket' => env('AWS_BUCKET'),
  20. 'url' => env('AWS_URL'),
  21. 'endpoint' => env('AWS_ENDPOINT'),
  22. 'use_path_style_endpoint' => env('AWS_USE_PATH_STYLE_ENDPOINT', false),
  23. 'throw' => false,
  24. ],
  25. ],


值得注意的是,我(目前)通过WAMP在本地托管它,在我切换PC之前,它似乎没有任何问题

n3h0vuf2

n3h0vuf21#

在公共空间中删除存储文件夹然后使用
第一个月
再次

相关问题