最近项目移到云服务器,所以需要处理一下

Step 1. 初始化OSSClient
SDK与OSS后台服务所有的交互都是通过OSSClient完成的。通过以下代码,可以生成OSSClient的实例: <?php require_once '/path/to/sdk/aliyun.php'; use \Aliyun\OSS\OSSClient; $client = OSSClient::factory(array(
'AccessKeyId' => '<access-key-id>',
'AccessKeySecret' => '<access-key-secret>',
));
由于SDK使用了命名空间机制,需要在文件开始声明使用 \Aliyun\OSS\OSSClient 类。 OSSClient使用工厂方法构建了一个OSSClient实例,此方法接收一个array作为输入参数;array中的 AccessKeyId 和 AccessKeySecret 是由系统分配给用户的ID对,用于标识用户,为访问OSS做签名验证。 我们看到,上面的例子通过在array中设置 key-value 对来传递参数。之后要介绍的大部分SDK接口也是通过这种形式来使用的。 Step 2. 创建Bucket
你可以通过以下代码来创建Bucket: <?php $client->createBucket(array(
'Bucket' => 'your-bucket-name',
));
通过指定 Bucket 参数来制定Bucket的名字,Bucket的名称有全局唯一性,请尽量保证你的Bucket名称不与别人的重复。 关于Bucket的命名规范,参见 Bucket命名规范 。 Step 3. 上传Object
Object可以简单的理解成一个文件,你可以通过以下代码把Object上传到一个Bucket中: <?php
$client->putObject(array(
'Bucket' => 'your-bucket-name',
'Key' => 'your-object-key',
'Content' => 'This is my content',
));
我们通过 Bucket 和 Key 来指定Object所在的Bucket以及Object的名字。 Content 为Object的实际内容,它可以为字符串或者是资源类型(resource),当 Content 类型为resource时,你必须指定Object的大小(以字节为单位)。 比如: <?php $client->putObject(array(
'Bucket' => 'your-bucket-name',
'Key' => 'your-object-key',
'Content' => fopen('/path/to/file', 'r'),
'ContentLength' => filesize('/path/to/file'),
));
关于Object的命名规范,参见 Object命名规范 。 关于上传Object更详细的信息,参见 上传Object 。 Step 4. 获取Object列表
你可能想知道在一个Bucket中存的Object是什么,通过 listObjects 接口可以达到这一目的: <?php $objectListing = $client->listObjects(array(
'Bucket' => 'your-bucket-name',
)); foreach ($objectListing->getObjectSummarys() as $objectSummary) {
echo $objectSummary->getKey();
}
listObjects 接口会返回 \Aliyun\OSS\Model\ObjectListing 对象,你可以通过对象的 getObjectSummarys 方法获取Object的列表。 Step 5. 下载Object
通过下面代码我们可以获取一个已经上传了的Object的内容: <?php $object = $client->getObject(array(
'Bucket' => 'your-bucket-name',
'Key' => 'your-object-key',
)); echo (string)$object;
事实上,getObject 方法返回了一个 \Aliyun\OSS\Model\OSSObject 的对象,此对象包含了Object的一些信息,以及一个可以用来读取object内容的resource类型的成员。 <?php $object = $client->getObject(array(
'Bucket' => 'your-bucket-name',
'Key' => 'your-object-key',
)); echo "Key: " . $object->getKey() . "\n";
echo "Update Date: " . $object->getLastModified()->getTimestamp() . "\n";
echo "Content: \n";
echo stream_get_contents($object->getObjectContent()); // Print object's content.
Step 6. 处理异常
当我们执行一些错误的操作,比如试图获取一个不存在的bucket的Object列表的时候,SDK会抛出类型为 \Aliyun\OSS\Exceptions\OSSException 的异常;另外,由于网络错误等原因,client也有可能抛出 \Aliyun\Common\Exceptions\ClientException 异常。你可以catch这些异常: <?php try {
$client->listObjects(array(
'Bucket' => 'bucket-non-exist',
));
} catch (\Aliyun\OSS\Exceptions\OSSException $ex) {
echo "Error: " . $ex->getErrorCode() . "\n";
} catch (\Aliyun\Common\Exceptions\ClientException $ex) {
echo "ClientError: " . $ex->getMessage() . "\n";
}
为了更简明地阐述SDK的使用,本文档的大多数实例代码都没有对异常进行处理。但是,在实际的开发中,为了实现程序的健壮性,你都应该捕获这些异常并处理它们。

一个实际的

public function zz() {

        if (IS_POST) {
P($_FILES); foreach ($_FILES as $value) {
foreach ($value["error"] as $k => $v) {
if ($v == 1) {
echo $err = $value['name'][$k] . '超过了php.ini的upload_max_filesize最大上传文件大小';
// return false;
} elseif ($v == 2) {
echo $err = $value['name'][$k] . '超过了浏览器表单的最大上传文件大小';
// return false;
} elseif ($v == 3) {
echo $err = $value['name'][$k] . '上传的文件仅部分上传';
// return false;
} elseif ($v == 4) {
echo $err = $value['name'][$k] . '没有上传文件';
// return false;
} elseif ($v == 6) {
echo $err = $value['name'][$k] . '缺少系统临时文件夹或者无写入权限';
// return false;
} elseif ($v == 7) {
echo $err = $value['name'][$k] . '系统错误,写入磁盘失败';
// return false;
} elseif ($v == 8) {
echo $err = $value['name'][$k] . 'PHP扩展程序停止文件上传';
// return false;
}
}
} // 处理文件数组
$bucketName = Common::getBucketName();
$ossClient = Common::getOssClient();
if (is_null($ossClient)) {
$err = 'oss对象获取失败!';
return false;
}
$upload_root = C('SERVERFILE_ROOT');
$category = 'zx';
$folder = "/{$category}/" . date('Ym/d', time()); echo $upload_folder = $upload_root . $folder;
$objectListing = $ossClient->createObjectDir($bucketName, $upload_folder); //创建目录,防止时间24点出现目录错误
             upload_folder 注意要为 'zx/tt/ll',前后不要有/不然会出错
            if ($objectListing['info']['http_code'] != 200) {
myLog($objectListing, 'oss_log');
echo $err = '文件创建失败';
}
$filename = array();
foreach ($_FILES as $value) {
foreach ($value['tmp_name'] as $k => $v) {
$filename[$k]['name'] = $value['name'][$k];
$filename[$k]['local_path'] = $value['tmp_name'][$k];
$filename[$k]['folder'] = $upload_folder;
$filename[$k]['size'] = $value['size'][$k];
$filename[$k]['type'] = $value['type'][$k];
$des_name_suffix = substr(strrchr($value['name'][$k], '.'), 1);
$des_name = microtime_format('YmdHisx', microtime(true)) . rand(100, 999) . rand(10, 99);
$filename[$k]['file_name'] = $des_name . '.' . $des_name_suffix;
$filename[$k]['extension'] = $des_name_suffix;
$filename[$k]['destination_name'] = $bucketName . $filename[$k]['folder'] . $des_name . '.' . $des_name_suffix; //存储在OSS里面最后的名字
}
} $return_array = array();
foreach ($filename as $kk => $vv) {
$return = $ossClient->uploadFile($bucketName, ($upload_folder . '/' . $vv['file_name']), $vv['local_path']);
($upload_folder . '/' . $vv['file_name'])注意这个目录一定要是 'zx/tt/ll',前后不要有/不然会出错
                if ($return['info']['http_code'] == 200) {
$return_array[$kk]['savename'] = $vv['file_name'];
$return_array[$kk]['type'] = $vv['type'];
$return_array[$kk]['size'] = $vv['size'];
$return_array[$kk]['extension'] = $vv['extension'];
$return_array[$kk]['savepath'] = '/' . $upload_folder . $vv['file_name'];
$return_array[$kk]['hash'] = $return['content-md5'];
$return_array[$kk]['oss_url'] = $return['info']['url'];
} else {
myLog($return, 'api_log');
$err = 'HTTP头部信息返回错误!';
}
} P($filename);
P($return_array);
}
$this->display();
}

实例demo 请入群下载

阿里OSS存储,php版demo的更多相关文章

  1. 阿里云存储OSS之九大使用技巧

    http://www.biphp.com/cloud-computing/%E9%98%BF%E9%87%8C%E4%BA%91%E5%AD%98%E5%82%A8oss%E4%B9%8B%E4%B9 ...

  2. Java项目接入阿里云OSS存储

    需求背景 目前公司内部项目所支持的文件云存储方式还是公司内部项目组提供的方案,但在时间的考验之下,弊端显现,尤其是灾备切换过程中需要切换访问地址,这种操作不方便,更可能因为中间过程的失误导致资源不可用 ...

  3. php将图片存储在阿里云oss存储上

    创建两个方法 1.上传方法 use OSS\OssClient; use think\Config; use OSS\Core\OssException; /** * 存储文件 * * @param ...

  4. 备份MySQL数据库并上传到阿里云OSS存储

    1. 环境配置 要将本地文件上传到阿里云oss中, 必须使用阿里云提供的工具 ossutil, 有32位,也有64位的, Linux和Windows都有.具体可以到阿里云官网下载 官网及文档: htt ...

  5. 【工具-代码】OSS阿里云存储服务-代码实现

    上一章节[工具]OSS阿里云存储服务--超级简单--个人还是觉得Fastdfs好玩 https://www.cnblogs.com/Yangbuyi/p/13488323.html 接上一个文章讲解还 ...

  6. 前端(react)上传到阿里云OSS存储 实例

    需求背景 由于现有的后台管理系统,上传的视频越来越大,加上上传视频较慢,后端小哥提出直接从前端上传视频或者其他文件到阿里云OSS存储. 阿里云OSS 阿里云OSS文档介绍,这里不做过多赘述 安装 原本 ...

  7. Haproxy内网连接阿里云存储OSS后提供下载

    global log 127.0.0.1 local0 maxconn #最大连接数 chroot /usr/local/haproxy uid #所属运行的用户UID gid #所属运行用用户组 d ...

  8. ASP版_阿里大于短信API Demo

    阿里大于申请地址:http://www.alidayu.com 阿里大于短信发送Demo: ******index.asp************* <%@LANGUAGE="VBSC ...

  9. 选择阿里云数据库HBase版十大理由

    根据Gartner的预计,全球非关系型数据库(NoSQL)在2020~2022预计保持在30%左右高速增长,远高于数据库整体市场. 阿里云数据库HBase版也是踏着技术发展的节奏,伴随着NoSQL和大 ...

随机推荐

  1. SpringBoot乱码

    第一步: 第一步,约定好传参编码格式 不管是运用httpclient,还是原生http,都要设置传参的编码,为了统一,这儿全部设置为utf-8 第二步,修正application.properties ...

  2. 基于java实现的简单区块链

    技术:maven3.0.5 + jdk1.8   概述 区块链是分布式数据存储.点对点传输.共识机制.加密算法等计算机技术的新型应用模式.所谓共识机制是区块链系统中实现不同节点之间建立信任.获取权益的 ...

  3. shell 实例

    转载自:https://github.com/liquanzhou/ops_doc    这里只作为笔记使用,不做他用 shell实例手册 0 说明{ 手册制作: 雪松 更新日期: 2018-09-1 ...

  4. Atitit 关于共享经济之共享男女朋友的创业计划

    Atitit 关于共享经济之共享男女朋友的创业计划 1. 共享经济的历史与趋势 1 1.1. 共享经济三大特征=产能过剩+共享平台+人人参与. 1 1.2. 共享经济是个大趋势,使用权渐渐的取代所有权 ...

  5. linux安全配置检查脚本_v0.8

    脚本环境:RHEL6.* 脚本说明:该脚本作用为纯执行检测不涉及更改配置等操作,与直接上来就改安全配置等基线脚本相比相对安全一些.虽然如此,在你执行该脚本之前仍然建议你备份或快照一下目标系统. 代码部 ...

  6. 【iCore1S 双核心板_ARM】例程二十:UART_IAP_ARM实验——更新升级STM32

    实验现象及操作说明: 1.本例程共有两个代码包,APP和IAP,IAP程序功能实现将APP程序升级至STM32中. 2.直接上电或烧写程序将执行升级的APP应用程序. BIN升级文件产生方法: 1.编 ...

  7. C语言 · 年龄巧合

    标题:年龄巧合 小明和他的表弟一起去看电影,有人问他们的年龄.小明说:今年是我们的幸运年啊.我出生年份的四位数字加起来刚好是我的年龄.表弟的也是如此.已知今年是2014年,并且,小明说的年龄指的是周岁 ...

  8. kernel事件通知userspace

    https://stackoverflow.com/questions/31646466/how-to-send-signal-from-kernel-to-user-space

  9. 通过端口映射连接不同网段的oracle

    oracle在内网,只有特殊机器能访问,通过做端口映射,可以以这个特殊机器作为“跳板”完成本机对远程oracle的连接. “跳板”机器是windows,需要在该机器上执行netsh命令: netsh ...

  10. spring JdbcTemplate数据库

    DAO package DAO; import org.springframework.jdbc.core.JdbcTemplate; public class OrderDao { private ...