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


Posted in PHP onSeptember 19, 2017

主要思路,在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文件的上传和删除已经写完了。当初自己也是遇到了很多问题,发现从网上找,竟然找不到理想的参考代码。所以才写了这几篇文章。希望对大家的开发有所帮助。毕竟水平有限,如果遇到考虑不周或者代码有误的地方,请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

PHP 相关文章推荐
PHP:风雨欲来 路在何方?
Oct 09 PHP
几种显示数据的方法的比较
Oct 09 PHP
深入eAccelerator与memcached的区别详解
Jun 06 PHP
深入解析php中的foreach函数
Aug 31 PHP
php写的AES加密解密类分享
Jun 20 PHP
php查找指定目录下指定大小文件的方法
Nov 28 PHP
php获取用户浏览器版本的方法
Jan 03 PHP
php+mysqli批量查询多张表数据的方法
Jan 29 PHP
PHP入门教程之操作符与控制结构流程详解
Sep 09 PHP
laravel5.4生成验证码的实例讲解
Aug 05 PHP
PHP实现二维数组按照指定的字段进行排序算法示例
Apr 23 PHP
laravel框架select2多选插件初始化默认选中项操作示例
Feb 18 PHP
yii2.0整合阿里云oss上传单个文件的示例
Sep 19 #PHP
yii2.0整合阿里云oss的示例代码
Sep 19 #PHP
PHP文件系统管理(实例讲解)
Sep 19 #PHP
Laravel学习教程之View模块详解
Sep 18 #PHP
php制作圆形用户头像的实例_自定义封装类源代码
Sep 18 #PHP
PHP中使用jQuery+Ajax实现分页查询多功能操作(示例讲解)
Sep 17 #PHP
PHP实现深度优先搜索算法(DFS,Depth First Search)详解
Sep 16 #PHP
You might like
在win系统安装配置 Memcached for PHP 5.3 图文教程
2015/03/03 PHP
PHP判断文件是否被引入的方法get_included_files用法示例
2016/11/29 PHP
PHP随机获取未被微信屏蔽的域名(微信域名检测)
2017/03/19 PHP
jQuery ui 1.7更新小结
2009/08/15 Javascript
Jquery 弹出层插件实现代码
2009/10/24 Javascript
js 多浏览器分别判断代码
2010/04/01 Javascript
在HTML代码中使用JavaScript代码的例子
2014/10/16 Javascript
js实现屏幕自适应局部代码分享
2015/01/30 Javascript
浅谈javascript中的闭包
2015/05/13 Javascript
Vue结合原生js实现自定义组件自动生成示例
2017/01/21 Javascript
如何快速上手Vuex
2017/02/14 Javascript
Django使用多数据库的方法
2017/09/06 Javascript
JS实现的简单四则运算计算器功能示例
2017/09/27 Javascript
js操作二进制数据方法
2018/03/03 Javascript
浅谈VUE-CLI脚手架热更新太慢的原因和解决方法
2018/09/28 Javascript
Vuex实现数据增加和删除功能
2019/11/11 Javascript
在vue和element-ui的table中实现分页复选功能
2019/12/04 Javascript
Ant Design Vue 添加区分中英文的长度校验功能
2020/01/21 Javascript
[01:10]DOTA2次级职业联赛 - U5战队宣传片
2014/12/01 DOTA
[01:58]2018DOTA2亚洲邀请赛趣味视频——交流
2018/04/03 DOTA
[03:11]完美世界DOTA2联赛PWL DAY8集锦
2020/11/09 DOTA
Python通过正则表达式选取callback的方法
2015/07/18 Python
Python中遇到的小问题及解决方法汇总
2017/01/11 Python
Python实现多进程的四种方式
2019/02/22 Python
Python学习笔记之变量、自定义函数用法示例
2019/05/28 Python
Python 运行.py文件和交互式运行代码的区别详解
2019/07/02 Python
python正则爬取某段子网站前20页段子(request库)过程解析
2019/08/10 Python
django API 中接口的互相调用实例
2020/04/01 Python
Python实现从N个数中找到最大的K个数
2020/04/02 Python
Python自动发送和收取邮件的方法
2020/08/12 Python
亚瑟士美国官网:ASICS美国
2017/02/01 全球购物
金蝶的一道SQL笔试题
2012/12/18 面试题
2014旅游局党组书记党建工作汇报材料
2014/11/02 职场文书
董事长年会致辞
2015/07/29 职场文书
详解MySQL 联合查询优化机制
2021/05/10 MySQL
简单聊一聊SQL注入及防止SQL注入
2022/03/23 MySQL