我需要解决在修改相关注册表时我提出的图像更新带来的一些小麻烦。
当我修改注册表时,我想替换目录中的相关文件。
这是我的表结构:
Schema::create('institutions', function(Blueprint $table)
{
$table->engine = 'InnoDB';
$table->increments('id');
$table->string('name')->unique();
$table->string('initials')->nullable();
$table->string('description')->nullable();
$table->string('avatar')->default('default.jpg');
$table->timestamps();
});
这是我控制器上的更新方法:
public function update(Request $request, $id)
{
//
$institution = $this->institution->find($id);
try
{
$institution->update($request->all());
if($request->hasFile('avatar')){
$avatar = $request->file('avatar');
$filename = time() . '.' . $avatar->getClientOriginalExtension();
Image::make($avatar)->resize(250, 205)->save( public_path('uploads/institutions/' . $filename ) );
$institution->avatar = $filename;
$institution->save();
}
$updated = $institution;
$message = flash('Institución actualizada correctamente!!!', 'success');
return redirect()->route('instituciones.index')->with('message', $message);
}
catch(\Illuminate\Database\QueryException $e)
{
$message = flash('La institución no se actualizó correctamente!!!', 'danger');
return redirect()->route('institutions.create')->with('message', $message);
}
}
我尝试了不同的方法,但我没有成功。
答案 0 :(得分:5)
上传的图片必须具有相同的文件名才能替换旧图片,但在这种情况下,由于time()
方法,它不会被替换。
您可以通过从数据库获取文件名并删除新图像来删除旧文件
//find data by id
$institution = $this->institution->find($id);
$filename = public_path('uploads/institutions/').$institution->avatar;
if(File::exists($filename)) {
$avatar = $request->file('avatar');
$filename_new = time() . '.' . $avatar->getClientOriginalExtension();
Image::make($avatar)->resize(250, 205)->save( public_path('uploads/institutions/' . $filename_new ) );
//update filename to database
$institution->avatar = $filename_new;
$institution->save();
//Found existing file then delete
File::delete($filename); // or unlink($filename);
}
希望它会有所帮助