我已经尝试更新类别信息,并且它已经更新,但没有在数据库中更新。我正在尝试在$category->update();之前返回$category;,并查看它的更新。但是在数据库中没有看到更新的数据。

1.网络
// Admin Dashboard Route路由:前缀(‘admin’)->middleware(‘auth’,‘isAdmin’)->group(函数() {
Route::get('dashboard', [App\Http\Controllers\Admin\DashboardController::class, 'index']);
// Category Route
Route::controller(App\Http\Controllers\Admin\CategoryController::class)->group(function () {
Route::get('/category', 'index');
Route::get('/category/create', 'create');
Route::post('/category', 'store');
Route::get('/category/view/{id}', 'view');
Route::get('/category/{category}/edit', 'edit');
Route::put('/category/{category}', 'update');
});});
2.控制器
public function update(CategoryFormRequest $request, $category){
$category = Category::findOrFail($category);
$validatedData = $request->validated();
$category = new Category;
$category->name = $validatedData['name'];
$category->slug = Str::slug($validatedData['slug']);
$category->description = $validatedData['description'];
if($request->hasFile('image')){
$path = 'uploads/category/' .$category->image;
if(File::exists($path)){
File::delete($path);
}
$file = $request->file('image');
$ext = $file->getClientOriginalExtension();
$fileName = 'PC' .'-'. time() .'.'. $ext;
$file->move('uploads/category/', $fileName);
$category->image = $fileName;
}
$category->meta_title = $validatedData['meta_title'];
$category->meta_keywords = $validatedData['meta_keywords'];
$category->meta_description = $validatedData['meta_description'];
$category->status = $request->status == true ? '0':'1';
$category->update();
return $category;
return redirect('admin/category')->with('message','Category Updated Successfully');
}3.视图
@extends('layouts.admin')@区段(内容)
<div class="row">
<div class="col-md-12">
<div class="card">
<div class="card-header d-flex align-items-center justify-content-between">
<h4 class="mb-0">Edit Category</h4>
<a href="{{ url('admin/category') }}" class="btn btn-primary btn-sm float-end text-light">View Category</a>
</div>
<form action="{{ url('admin/category/'.$category->id) }}" method="POST" enctype="multipart/form-data">
@method('PUT')
@csrf
<div class="card-body">
<div class="row">
<div class="col-md-12 mb-3">
<label for="" class="form-label">Status</label>
<input type="checkbox" name="status" {{ $category->status == 0 ? 'Checked':'' }}>
</div>
<div class="col-md-6 mb-3">
<label for="" class="form-label">Name</label>
<input type="text" class="form-control" name="name" id="" value="{{ $category->name }}" placeholder="Enter category name">
@error('name')
<small class="text-danger">{{ $message }}</small>
@enderror
</div>
<div class="col-md-6 mb-3">
<label for="" class="form-label">Slug</label>
<input type="text" class="form-control" name="slug" id="" value="{{ $category->slug }}" placeholder="Enter category slug">
@error('slug')
<small class="text-danger">{{ $message }}</small>
@enderror
</div>
<div class="col-md-6 mb-3">
<label for="" class="form-label">Image</label>
<input type="file" class="form-control" name="image" id="">
<img src="{{ asset('uploads/category/' .$category->image) }}" width="60" height="60" class="img-fluid rounded-top" alt="">
@error('image')
<small class="text-danger">{{ $message }}</small>
@enderror
</div>
<div class="col-md-6 mb-3">
<label for="" class="form-label">Description</label>
<textarea class="form-control" name="description" id="" rows="5" placeholder="Enter Description">{{ $category->description }}</textarea>
@error('description')
<small class="text-danger">{{ $message }}</small>
@enderror
</div>
<div class="col-md-12 mb-3">
<h4>SEO Tags</h4>
</div>
<div class="col-md-12 mb-3">
<label for="" class="form-label">Meta Title</label>
<input type="text" class="form-control" name="meta_title" value="{{ $category->meta_title }}" id="" placeholder="Enter meta title">
@error('meta_title')
<small class="text-danger">{{ $message }}</small>
@enderror
</div>
<div class="col-md-12 mb-3">
<label for="" class="form-label">Meta Keywords</label>
<textarea class="form-control" name="meta_keywords" id="" rows="3" placeholder="Enter Meta keywords">{{ $category->meta_keywords }}</textarea>
@error('meta_keywords')
<small class="text-danger">{{ $message }}</small>
@enderror
</div>
<div class="col-md-12 mb-3">
<label for="" class="form-label">Meta Description</label>
<textarea class="form-control" name="meta_description" id="" rows="3" placeholder="Enter Meta Description">{{ $category->meta_description }}</textarea>
@error('meta_description')
<small class="text-danger">{{ $message }}</small>
@enderror
</div>
</div>
</div>
<div class="card-footer">
<div class="col-12 text-center">
<button type="submit" class="btn btn-primary text-light">Update Category</button>
</div>
</div>
</form>
</div>
</div>
</div>@endsection节
发布于 2022-11-05 06:27:50
用update更改save
$category->meta_title = $validatedData['meta_title'];
$category->meta_keywords = $validatedData['meta_keywords'];
$category->meta_description = $validatedData['meta_description'];
$category->status = $request->status == true ? '0':'1';
$category->save();发布于 2022-11-05 06:38:43
代码中有两个错误步骤:
从db获取类别记录后,您将创建新副本,应删除此步骤。然后,您应该使用save()方法,而不是更新。
$category = Category::findOrFail($category);
$validatedData = $request->validated();
// $category = new Category; remove this line
$category->name = $validatedData['name'];
$category->slug = Str::slug($validatedData['slug']);
$category->description = $validatedData['description'];
if($request->hasFile('image')){
$path = 'uploads/category/' .$category->image;
if(File::exists($path)){
File::delete($path);
}
$file = $request->file('image');
$ext = $file->getClientOriginalExtension();
$fileName = 'PC' .'-'. time() .'.'. $ext;
$file->move('uploads/category/', $fileName);
$category->image = $fileName;
}
$category->meta_title = $validatedData['meta_title'];
$category->meta_keywords = $validatedData['meta_keywords'];
$category->meta_description = $validatedData['meta_description'];
$category->status = $request->status == true ? '0':'1';
$category->save(); // save not update
return $category;发布于 2022-11-07 01:42:23
您可以使用路由模型绑定缩短代码,然后使用上面提到的save()方法。
public function update(CategoryFormRequest $request, Category $category){
$validatedData = $request->validated();
// $category = new Category; remove this line
$category->name = $validatedData['name'];
$category->slug = Str::slug($validatedData['slug']);
$category->description = $validatedData['description'];
if ($request->hasFile('image')) {
$path = 'uploads/category/' . $category->image;
if (File::exists($path)) {
File::delete($path);
}
$file = $request->file('image');
$ext = $file->getClientOriginalExtension();
$fileName = 'PC' . '-' . time() . '.' . $ext;
$file->move('uploads/category/', $fileName);
$category->image = $fileName;
}
$category->meta_title = $validatedData['meta_title'];
$category->meta_keywords = $validatedData['meta_keywords'];
$category->meta_description = $validatedData['meta_description'];
$category->status = $request->status == true ? '0' : '1';
$category->save(); // save not update
return $category;
return redirect('admin/category')->with('message','Category Updated Successfully');
}如果您真的想使用update()方法,也可以:
public function update(CategoryFormRequest $request, Category $category){
$validated = $request->validated();
$filename;
if($request->hasFile('image')){
$path = 'uploads/category/' .$category->image;
if(File::exists($path)){
File::delete($path);
}
$file = $request->file('image');
$ext = $file->getClientOriginalExtension();
$fileName = 'PC' .'-'. time() .'.'. $ext;
$file->move('uploads/category/', $fileName);
}
$category->update([
'name' => $$validated['name'],
'slug' => Str::slug($$validated['slug']),
'description' => $$validated['description'],
'meta_title' => $$validated['meta_title'],
'meta_keywords' => $$validated['meta_keywords'],
'meta_description' => $$validated['meta_description'],
'status' => $validated['status'] == true ? '0' : '1',
'image' => $filename,
]);
return $category;
return redirect('admin/category')->with('message','Category Updated Successfully');
}https://stackoverflow.com/questions/74325560
复制相似问题