Yii2.0使用阿里云OSS的SDK上传图片、下载、删除图片示例
程序员文章站
2022-06-23 10:59:39
之前从没接触过yii,借助的各方资源来做的这个整合阿里云oss的sdk上传图片实例,如果有不正之处请指出!
前面参照了weinirumo 的介绍,大家可以自行去查看。...
之前从没接触过yii,借助的各方资源来做的这个整合阿里云oss的sdk上传图片实例,如果有不正之处请指出!
前面参照了weinirumo 的介绍,大家可以自行去查看。
好了,下面开始进入主题:
准备工作:需要使用composer执行命令,如果没有安装composer的需要提前安装,参考文档:
1、项目目录结构
我使用的是基础版,只有后台目录,请自行对照自己的项目目录结构,会用到以下的几个目录:
2、在项目根目录下运行cmd命令
3、执行composer命令
切换到中国国内镜像
复制代码 代码如下:
composer config -g repo.packagist composer
执行加载sdk命令
composer require aliyuncs/oss-sdk-php
4、查看根目录/vendor/里面,会增加以下目录文件,说明安装依赖文件成功:
5、在根目录/common/里面新建components目录,新建aliyunoss.php文件
需要注意项目的命名空间,引入文件
6、根目录/common/components/aliyunoss.php代码:
<?php /** * @author: marte * @date: 2017-09-04 11:31:20 * @last modified by: marte * @last modified time: 2017-09-06 16:19:28 */ namespace common\components; use yii; use yii\base\component; use oss\ossclient; use oss\croe\ossexception; class aliyunoss extends component { public static $oss; public function __construct() { parent::__construct(); $accesskeyid = yii::$app->params['oss']['accesskeyid']; //获取阿里云oss的accesskeyid $accesskeysecret = yii::$app->params['oss']['accesskeysecret']; //获取阿里云oss的accesskeysecret $endpoint = yii::$app->params['oss']['endpoint']; //获取阿里云oss的endpoint self::$oss = new ossclient($accesskeyid, $accesskeysecret, $endpoint); //实例化ossclient对象 } /** * 使用阿里云oss上传文件 * @param $object 保存到阿里云oss的文件名 * @param $filepath 文件在本地的绝对路径 * @return bool 上传是否成功 */ public function upload($object, $filepath) { // $res = false; $bucket = yii::$app->params['oss']['bucket']; //获取阿里云oss的bucket $result=array(); try{ $getossinfo=self::$oss->uploadfile($bucket, $object, $filepath); $result['url'] = $getossinfo['info']['url']; if($getossinfo['info']['url']){ @unlink(substr($_path, 1)); } }catch(ossexception $e){ var_dump($e); return; }; $url=$result['url']; return $url; // var_dump("$url");die(); // $res = true; // return $url; } /** * 删除指定文件 * @param $object 被删除的文件名 * @return bool 删除是否成功 */ public function delete($object) { $res = false; $bucket = yii::$app->params['oss']['bucket']; //获取阿里云oss的bucket if (self::$oss->deleteobject($bucket, $object)){ //调用deleteobject方法把服务器文件上传到阿里云oss $res = true; } return $res; } //测试 public function test(){ echo 123; echo "success"; } }
7、在根目录/common/config/main.php,添加:
'aliyunoss' => [ 'class' => 'common\components\aliyunoss', ],
8、在根目录/common/config/params.php,添加sdk信息,代码需要自行修改
'oss' =>[ //阿里云oss 'ossserver' => 'oss-cn- .aliyuncs.com', //服务器外网地址, 'ossserverinternal' => 'oss-cn- .aliyuncs.com', //服务器内网地址 'accesskeyid'=>' ', 'accesskeysecret'=>' ', 'bucket' => ' ', 'endpoint' => ' ', ],
9、根目录/backend/controllers/控制器名.php,里面引用文件
//阿里云oss执行 use common\components\aliyunoss;
由于上传图片限制,自此至下面就看代码了
10、准备上传图片数据,
public function actionadd(){ $img_banner = trim($_files['vend_banner']['name']); $img_banner = explode('.',$img_banner); $imgs_banner = $img_banner[1]; $img_banner = date('ymdhis').mt_rand(100,1000).md5($img_banner[0]); //文件重命名 $vend_banners = "./images/upload/".$img_banner.'.'.$imgs_banner; $vend_banner = $img_banner.'.'.$imgs_banner; $uploadpath = dirname(dirname(__file__)).'/web/images/upload/'; // 取得临时文件路径 if (!file_exists($uploadpath)) { @mkdir($uploadpath, 0777, true); } $file_path_vend_banner = $uploadpath.$vend_banner; $filepath_vend_banner=str_replace("\\", "/",$file_path_vend_banner);//绝对路径,上传第二个参数 $object_vend_banner="data/company/".$vend_banner; //拼接存储路径和文件名称,上传第一个参数 if(is_uploaded_file($_files['vend_banner']['tmp_name'])){ //判断是否post上传 if(!move_uploaded_file($_files['vend_banner']['tmp_name'],$vend_banners)){ //移动到临时目录里 echo 'banner上传失败';exit(); } } $vend_banner_url = yii::$app->aliyunoss->upload($object_vend_banner,$filepath_vend_banner); //调用新建的文件,执行oss上传,返回的是上传到阿里云的oss文件路径,打印出来是: //string(116) "http:// ******.oss-cn-******.aliyuncs.com/data/company/20170908124236303cc17c30cd111c7215fc8f51f8790e0e1.jpg"
11、删除图片
$oss_url=$data2[0]['vend_banner'];//只要(上传时候的)图片名, $object="data/company/".$oss_url; //将你阿里云的存储路径+图片名=组成数据 $is_del = yii::$app->aliyunoss->delete($object);//删除指定的图片,返回true,否则返回false
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: Python中表示字符串的三种方法
下一篇: JavaScript两种定时器的使用