gpt4 book ai didi

php - Laravel 5.1 类 Illuminate\Database\Eloquent\Relations\HasMany 的对象无法转换为字符串

转载 作者:搜寻专家 更新时间:2023-10-31 21:05:34 24 4
gpt4 key购买 nike

I have problem with my laravel 5.1 error Object of class Illuminate\Database\Eloquent\Relations\HasMany could not be converted to string when i click delete

GalleryController.php

public function deleteGallery($id)
{
//load the gallery
$currentGallery = Gallery::findOrfail($id);

// check ownership
if ($currentGallery->created_by != Auth::user()->id) {
abort('403','You are not allowed to delete this gallery');
}

// get the images
$images = $currentGallery->images();

// delete the images
foreach ($currentGallery->$images as $image) {
unlink(public_path($image->file_path));
}

// delete the DB records
$currentGallery->images()->delete();

$currentGallery->delete();

return redirect()->back();
}

Route.php

Route::get('gallery/delete/{id}','GalleryController@deleteGallery');

Model Gallery.php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Gallery extends Model
{
protected $table = 'gallery';

public function images()
{
return $this->hasMany('App\Image');
}
}

模型Image.php

namespace App;

use Illuminate\Database\Eloquent\Model;

class image extends Model
{
protected $fillable = ['gallery_id', 'file_name', 'file_size', 'file_mime', 'file_path',
'created_by'];

public function gallery()
{
return $this->belongsTo('App\Gallery');
}

}

查看 gallery.blade.php

@extends('master')

@section('content')
<div class="row">
<div class="col-md-12">
<h1>My Gallery</h1>
</div>
</div>

<div class="row">
<div class="col-md-8">
@if ($galleries->count() > 0)
<table class="table table-striped table-bordered table-responsive">
<thead>
<tr class="info">
<th>Name of the gallery</th>
<th></th>
</tr>
</thead>
<tbody>
@foreach($galleries as $gallery)
<tr>
<td>{{$gallery->name}}
<span class="pull-right">
{{ $gallery->images()->count() }}
</span>
</td>
<td><a href="{{url('gallery/view/'.$gallery->id)}}">View</a> /
<a href="{{url('gallery/delete/'.$gallery->id)}}">Delete</a>
</td>
</tr>
@endforeach
</tbody>
</table>
@endif
</div>

<div class="col-md-4">
@if (count($errors) > 0)
<div class="alert alert-danger">
<ul>
@foreach ($errors->all() as $error)
<li>{{ $error }}</li>
@endforeach
</ul>
</div>
@endif
<form class="form" method="POST" action="{{url('gallery/save')}}">
<input type="hidden" name="_token" value="{{ csrf_token() }}">

<div class="form-group">
<input type="text" name="gallery_name"
id="gallery_name" placeholder="Name of the gallery"
class="form-control"
value="{{ old('gallery_name')}}" />
</div>

<button class="btn btn-primary">Save</button>
</form>
</div>
</div>

@endsection

最佳答案

在图库 Controller 中,您不需要获取图像,因为您没有在其他任何地方使用该变量。因此删除行

// get the images   
$images = $currentGallery->images();

只要让 foreach 为

// delete the images
foreach ($currentGallery->images as $image) {
unlink(public_path($image->file_path));
}

请注意使用$currentGallery->images

关于php - Laravel 5.1 类 Illuminate\Database\Eloquent\Relations\HasMany 的对象无法转换为字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32940769/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com