干预/图片上传错误{{图片来源不可读}}

Intervention / Image Upload Error {{ Image source not readable }}

我正在尝试在 Laravel 5.1 中添加个人资料图片上传。我使用了 Intervention/Image 包,但是当我尝试上传图像时出现此错误:

NotReadableException in AbstractDecoder.php line 302: Image source not readable

这是我的光控器:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Image;
use Input;
use App\Http\Requests;
use App\Http\Controllers\Controller;

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

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

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request)
    {
        $img = Image::make($request->file('photo')); 
        $img->save('image.png');  
    }

    /**
     * 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) {}
}

这是我的 html 表格:

<header>
    <div class="student_profile_sub_header w100">
        <div class="container ccenter">
            <div class="student_profile_name">
                <h4>{{$student->name}} {{$student->surname}}</h4>
            </div>
            <div class="student_profile_image">
                <img src="{{asset('assets/profile_image.png')}}">
            </div>

            <form method="POST" action="../student/profile/imageupload">
                {!! csrf_field() !!}
                <input type="file" name="photo">
                <input type="submit" value="Upload Image" name="submit">
                @foreach($errors->all() as $error)
                    <li>{{ $error }}</li>
                @endforeach
            </form>
        </div>
    </div>
</header>

在表单标签中添加以下参数:

enctype="multipart/form-data"

并在 make 中对此进行更改:

$img = Image::make($request->file('photo')->getRealPath());

尝试使用 laravel collective,如果您使用 laravel collective

,请确保您已检查文件是否正确
{{ Form::open(['route'=>'your-route', 'class'=>'form',**'files'=>true**]) }} 
{{ Form::close()}}`

,然后在存储函数中请求文件时添加 getRealPath(),如下所示 Image::make(Input::file('artist_pic')->getRealPath())->resize(120,75);

这不是为了回答 OP 的问题,而是为了回答其他人在不同上下文中提出的相同问题。

如果您使用的是 storeAs() 等文件系统方法,那么您实际上是在 /public/ 范围内的 /storage/app/public/ 下上传文件。如果是这样,您将需要 运行 以下命令:

php artisan storage:link

此命令将在 /public 目录下创建 link 到 /storage 目录的快捷方式,一切正常。

它是 $img=Image::make('photo')->resize(300, 200);

我改成了 $img=Image::make($request->file('photo'))->resize(300, 200);

并为我工作。