从控制器在 div 中显示图像?

Displaying image in a div from controller?

我正在将图像保存到 public 文件夹,现在我想在定义的 <div class="logo"> 中显示它如何实现?

控制器:

public function testing(Request $request) {
    if($request->hasFile('img'));
    {
        $image = Input::file('img');
        $filename = time() . '.' . $image->getClientOriginalExtension();
        $path = public_path('images/' . $filename);
        Image::make($image->getRealPath())->resize(200, 200)->save($path);
        $file = $request->file('img');
        return response()->file($file);
    }
}

JS:

function submitImage(){
    var fd = new FormData($("#upload_form")[0]);
        fd.append( 'img', $('#img') );

$.ajax({
      url:'template',
      data: fd,
      dataType:'json',
      async:false,
      type:'post',
      processData: false,
      contentType: false,
    });
}

Blade:

<form id="upload_form" action="{{ action('BuilderController@testing') }}" enctype="multipart/form-data" role="form" method="POST">
<input type="hidden" name="_token" value="{{ csrf_token() }}">
<input name="img" id="img" class="form-control filestyle margin images" data-input="false" type="file" data-buttonText="Upload Logo" data-size="sm" data-badge="false" onchange="submitImage();" />
</form>
<div class="logo">
    <img class="images" id="image" src="#" alt="Your Logo"/>
</div>

所以我想把src="#"改成保存图片的路径比如"C://xampp/htdocs/laravel/public/image/1.jpg"

将控制器方法中的return更改为:

return ['url' => url('images/' . $filename)];

然后将 success 方法添加到您的 ajax 调用中:

$.ajax({
    url:'template',
    data: fd,
    dataType: 'json',
    async: false,
    type: 'post',
    processData: false,
    contentType: false,
    success: function (data) {
        $("#image").attr("src", data.url)
    }
});

希望对您有所帮助!

将您的控制器代码更改为

public function testing(Request $request) {
    if($request->hasFile('img'));
    {
        $image = Input::file('img');
        $filename = time() . '.' . $image->getClientOriginalExtension();
        $path = public_path('images/' . $filename);
        Image::make($image->getRealPath())->resize(200, 200)->save($path);
        $file = $request->file('img');
        $response = [];
        $response['name'] = $path;
        return json_encode($response);
    }
}

并在您的 JS 中添加成功代码,这将更改图像的 url

$.ajax({
      url:'template',
      data: fd,
      dataType:'json',
      async:false,
      type:'post',
      success: function (data) {
         var img_loc = JSON.parse(data).name;
         $("#image").attr('src', img_loc);
      },
      processData: false,
      contentType: false,
    });
}