在Laravel 7.x中无法上传图片: "C:\xampp\tmp\phpE0A1.tmp" 这个错误显示在我的数据库banner_photo列中

问题描述 投票:0回答:1

我想在mysql数据库中上传图片,但是在banner_photo字段 "C:\xampp\tmp\phpE0A1.tmp "这个.tmp文件每次都自动生成。请大家帮忙找找问题所在,有什么办法解决!

我的 刀片 档案

@extends('admin.layout.master')

@section('content')
<div class="container-scroller">
      <!-- partial:partials/_navbar.html -->
      @include('admin.layout.nav')

      <!-- partial -->
    <div class="container-fluid page-body-wrapper">
        <!-- partial:partials/_sidebar.html -->
        @include('admin.layout.sidebar')
        <!-- partial -->
        <div class="main-panel">
          <div class="content-wrapper">
            <!-- Page Title Header Starts-->
            <div class="row page-title-header">
              <div class="col-12">
                <div class="page-header">
                  <h4 class="page-title">Dashboard</h4>

                </div>
              </div>

            </div>
            <!-- Page Title Header Ends-->


            <div class="row">
              <div class="col-md-12">
                <div class="row">
                  <div class="col-md-12 grid-margin">
                    <div class="card">
                      <div class="card-body">
                        <div class="d-flex justify-content-between">
                          <h4 class="card-title mb-0">Banner</h4>
                          <a href="#"><small>Show All</small></a>
                        </div>
                        <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Est quod cupiditate esse fuga</p>
                        <div class="table-responsive">
                          <table class="table table-striped table-hover">
                            <thead>
                              <tr>
                                <th>ID</th>
                                <th>H4 Title</th>
                                <th>H2 Title</th>
                                <th>Paragraph</th>
                                <th>Image</th>
                                <th>Edit</th>
                                <th>Delete</th>
                              </tr>
                            </thead>
                            <tbody>
                              @foreach($banners as $row)
                              <tr>
                                <td>{{$row->id}}</td>
                                <td>{{$row->h4_title}}</td>
                                <td>{{$row->h2_title}}</td>
                                <td>{{$row->banner_paragraph}}</td>
                                <td>{{$row->banner_photo}}</td>
                                <td><button type="submit" class="btn btn-primary"><i class="fas fa-edit"></i>EDIT</button></td>
                                <td><button type="submit" class="btn btn-danger"><i class="far fa-trash-alt"></i>DELETE</button></td>
                              </tr>
                              @endforeach
                            </tbody>
                          </table>
                        </div>
                      </div>
                    </div>
                  </div>


                </div>
              </div>

            </div>

          </div>
          <!-- content-wrapper ends -->
          <!-- partial:partials/_footer.html -->
          @include('admin.layout.footer')
          <!-- partial -->
        </div>
        <!-- main-panel ends -->
    </div>
      <!-- page-body-wrapper ends -->
</div>
<!-- container-scroller -->

@endsection

我的 web.php 档案

<?php

use Illuminate\Support\Facades\Route;

/*
|--------------------------------------------------------------------------
| Web Routes
|--------------------------------------------------------------------------
|
| Here is where you can register web routes for your application. These
| routes are loaded by the RouteServiceProvider within a group which
| contains the "web" middleware group. Now create something great!
|
*/

Route::get('/', function () {
    return view('index');
});

Route::get('/contact-us', function () {
    return view('contactus');
});

Route::get('/tours', function () {
    return view('tours');
});

// Admin panel Pages Routes

Route::get('/admin', function () {
    return view('admin/index');
});

Route::get('/admin/bannercustomize', function () {
    return view('admin/layout/bannercustomize');
});


// Controller routes

Route::post('store/banner','BannerController@store')->name('store.banner');

Route::get('/admin','BannerController@index')->name('admin.index');

我的 BannerController.php 档案

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Banner;
use Image;
use Illuminate\Support\Str;
use Illuminate\Http\UploadedFile;
use Illuminate\Support\Facades\Storage;

class BannerController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {


        $banners = Banner::all();
        return view('admin.index',compact('banners'));
    }


    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        return view('admin.layout.bannercustomize');
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */


    public function store(Request $request)
    {
        $this->validate($request, [
            'h4_title' => 'required',
            'h2_title' => 'required',
            'banner_paragraph' => 'required',
            'banner_photo' => 'required'


        ]);

        $banner = new Banner([
            'h4_title' => $request->get('h4_title'),
            'h2_title' => $request->get('h2_title'),
            'banner_paragraph' => $request->get('banner_paragraph'),
            'banner_photo' => $request->file('banner_photo')

        ]);

        $request->banner_photo->store('public/image/banner_image/');

        $banner->save();

        return redirect()->back()->with('success', 'Data Added');
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
        //
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
        //
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {
        //
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
        //
    }
}

N.B: 我使用的是Laravel 7.x.

php laravel eloquent laravel-5.8 laravel-7
1个回答
0
投票

当你上传一个文件时,php会给它起一个临时的名字和位置(比如......),直到你找到它为止。C:\xampp\tmp\phpE0A1.tmp),直到你在某个地方找到它。

通常你保存在数据库中的是文件的位置和名称,一旦文件位于你的项目目录中

所以,先存储文件,然后把路径保存在数据库中。

public function store(Request $request)
{
    $this->validate($request, [
        'h4_title' => 'required',
        'h2_title' => 'required',
        'banner_paragraph' => 'required',
        'banner_photo' => 'required|file'
    ]);

    $path = $request->file('banner_photo')->store('public/image/banner_image');

    $banner = new Banner([
        'h4_title' => $request->get('h4_title'),
        'h2_title' => $request->get('h2_title'),
        'banner_paragraph' => $request->get('banner_paragraph'),
        'banner_photo' => $path
    ]);

    $banner->save();

    return redirect()->back()->with('success', 'Data Added');
}

或者,既然你要把文件存储在... public/ 存储目录,您可以使用公共磁盘来存储文件。

$path = $request->file('banner_photo')->store(
    'image/banner_image', 'public'
);

奖金:

您可以通过您的网址访问它。index.blade 表。

<table class="table table-striped table-hover">
<thead>
    <tr>
    <th>ID</th>
    <th>H4 Title</th>
    <th>H2 Title</th>
    <th>Paragraph</th>
    <th>Image</th>
    <th>Edit</th>
    <th>Delete</th>
    </tr>
</thead>
<tbody>
    @foreach($banners as $row)
    <tr>
    <td>{{$row->id}}</td>
    <td>{{$row->h4_title}}</td>
    <td>{{$row->h2_title}}</td>
    <td>{{$row->banner_paragraph}}</td>
    <td><img src="{{ asset( Storage::url($row->banner_photo) ) }}" /></td>
    <td><button type="submit" class="btn btn-primary"><i class="fas fa-edit"></i>EDIT</button></td>
    <td><button type="submit" class="btn btn-danger"><i class="far fa-trash-alt"></i>DELETE</button></td>
    </tr>
    @endforeach
</tbody>
</table>

: 此外,你应该 建立象征性联系public/storage 这指的是 storage/app/public 目录。

参考文献。

文件存储 文件上传.

文件存储 公共磁盘.

文件存储 文件URL.

© www.soinside.com 2019 - 2024. All rights reserved.