yii2.0整合阿里云oss php sdk(三)删除单个文件 [ 2.0 版本 ]
主要思路,在controller里边通过获得要删除的文件fileid,把fileid传递给model的deletefile方法进行处理,并返回处理结果。
在deletefile方法里边,先根据id找到对应的文件信息,然后删除数据里边的记录和阿里云oss里边的文件和本地的文件。
主要步骤如下:
1 首先是构建一个view视图,或者写一个ajax发送请求,此处代码略(让前端去写吧)。
2 在控制器里边接收参数,并转交给model。控制器UploadController.php里边的代码参考如下:
/**
* 根据fileid删除文件
* @return mixed 删除是否成功
*/
public function actionDeletefile()
{
$res['error'] = 1; // 准备返回数据
Yii::$app->response->format = Response::FORMAT_JSON; // 设置返回格式
if (Yii::$app->request->isPost){ // 如果是post请求
$postdata = Yii::$app->request->post('fileid',0); // 从post里边获取文件id
if ($postdata==0){ // 如果文件id为0
$res['errmsg'] = '删除失败,请重试'; // 准备返回数据
return $res; // 返回结果
}
$model = new UploadForm(); // 实例化model
$delres = $model->deletefile($postdata); // 根据id调用deletefile方法
if ($delres['error']==0){ // 如果删除成功
$res['error'] = 0; // 准备返回信息
} else {
$res['errmsg'] = $delres['errmsg']; // 如果删除失败,准备返回信息
}
} else {
$res['errmsg'] = '非法请求'; // 主要考虑post请求,get请求请自行修改代码
}
return $res; // 返回删除结果
}
3 当controller把文件id转移给UploadForm.php以后,在deletefile方法里边进行删除。
/**
* 删除阿里云oss里存储的文件和数据库里边保存到文件上传信息
* @param $fileid 文件表里边的主键id
* @return boolean 删除是否成功
*/
public function deletefile($fileid)
{
$res['error'] = 1; // 1表示默认有错误。
$fileinfo = Yii::$app->db->createCommand('select ossfile,filePath,userid from file where id=:id')->bindParam(':id', $fileid)->queryOne();
// 根据主键从数据库里边查询文件的信息,至少要一个服务器文件的完整路径(用来删除服务器文件)和一个ossfile的名称(删除阿里云oss里边的文件)
if (count($fileinfo) > 0) { // 如果找到了文件的记录
// 这里边的验证可以更丰富一些,比如验证用户是否有权限删除该文件,文件是否属于该用户等等
$ossfile = $fileinfo['ossfile']; // 获取ossfile
$realfile = $fileinfo['filePath']; // 获取服务器上的文件
$owner = $fileinfo['userid']; // 获取上传图片用户的id
$operator = Yii::$app->user->id; // 获取删除图片的用户
if ($owner != $operator) { // 如果删除图片的用户不是上传的用户,报错并返回
$res['errmsg'] = '您删除的图片不存在';
return $res;
}
$trans = Yii::$app->db->beginTransaction(); // 开启事务
try {
$delstatus = Yii::$app->db->createCommand()->delete('file', 'id = ' . $fileid)->execute();
//删除数据库里边的记录
if ($delstatus) { // 如果删除成功
if (Yii::$app->Aliyunoss->delete($ossfile)) { //删除阿里云oss上的文件
@unlink($realfile); // 删除服务器上的文件
$res['error'] = 0; // 准备返回信息
$trans->commit(); // 提交事务
}
}
$trans->rollBack(); // 删除失败,事务回滚
} catch (Exception $e) { // 发生异常
$res['errmsg'] = '删除失败'; // 准备返回信息
$trans->rollBack(); // 事务回滚
}
} else {
$res['errmsg'] = '图片不存在,请重试'; // 图片不存在
}
return $res; // 返回删除结果
}
阿里云oss文件的上传和删除已经写完了。当初自己也是遇到了很多问题,发现从网上找,竟然找不到理想的参考代码。所以才写了这几篇文章。希望对大家的开发有所帮助。毕竟水平有限,如果遇到考虑不周或者代码有误的地方,欢迎私信交流,谢谢。
weinirumo
注册时间:2016-11-24
最后登录:2023-02-21
在线时长:43小时6分
最后登录:2023-02-21
在线时长:43小时6分
- 粉丝17
- 金钱6670
- 威望50
- 积分7600
热门源码
- 基于 Yii 2 + Bootstrap 3 搭建一套后台管理系统 CMF
- 整合完 yii2-rbac+yii2-admin+adminlte 等库的基础开发后台源码
- 适合初学者学习的一款通用的管理后台
- yii-goaop - 将 goaop 集成到 Yii,在 Yii 中优雅的面向切面编程
- yii-log-target - 监控系统异常且多渠道发送异常信息通知
- 店滴云1.3.0
- 面向对象的一小步:添加 ActiveRecord 的 Scope 功能
- Yii2 开源商城 FecShop
- 基于 Yii2 开发的多店铺商城系统,免费开源 + 适合二开
- leadshop - 基于 Yii2 开发的一款免费开源且支持商业使用的商城管理系统
共 3 条评论
用的这个 oss extension
https://github.com/yiier/yii2-aliyun-oss
可以自己加功能, 我加了个获取预签名url的函数给第三方来上传文件, 挺简单的
大神,问一下,为什么要先上传到服务器,然后从服务器再上传到阿里云oss呢,再删除服务器文件?不是可以直接从本地上传到oss吗?
可以直接上传到阿里云,可以看文档 https://help.aliyun.com/document_detail/31849.html?spm=5176.87240.400427.20.k4P60A
具体怎么做,看你们的需求吧,我只是给出了一个例子
可以直接上传到阿里云,可以看文档 https://help.aliyun.com/document_detail/31849.html?spm=5176.87240.400427.20.k4P60A
具体怎么做,看你们的需求吧,我只是给出了一个例子