yii2.0整合阿里云oss删除单个文件的方法

时间:2022-03-24 17:36:55

主要思路,在controller里边通过获得要删除的文件fileid,把fileid传递给model的deletefile方法进行处理,并返回处理结果。
在deletefile方法里边,先根据id找到对应的文件信息,然后删除数据里边的记录和阿里云oss里边的文件和本地的文件。

主要步骤如下:

1 首先是构建一个view视图,或者写一个ajax发送请求,此处代码略(让前端去写吧)。

2 在控制器里边接收参数,并转交给model。控制器UploadController.php里边的代码参考如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
/**
   * 根据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方法里边进行删除。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
/**
 * 删除阿里云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文件的上传和删除已经写完了。当初自己也是遇到了很多问题,发现从网上找,竟然找不到理想的参考代码。所以才写了这几篇文章。希望对大家的开发有所帮助。毕竟水平有限,如果遇到考虑不周或者代码有误的地方,请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!

原文链接:http://www.yiichina.com/code/1080