qcloud-cos-php-sdk

腾讯云对象存储服务 COS PHP SDK

安装

composer require jerray/qcloud-cos-php-sdk

使用方法

创建客户端实例

创建SDK客户端实例。$options中的参数请到腾讯云对象存储的密钥管理页面获取。

$options = [ 'appId' => 'Your app id', 'secretId' => 'Your secret id', 'secretKey' => 'Your secret key', ]; $cos = new jerrayQCloudCosQCloudCos($options);

各接口返回结果详情参见腾讯云对象存储服务 RESTful API文档

文件操作

完整上传

$localFilePath = '/path/to/a/local/file'; $bucketName = 'bucket'; $cosFilePath = '/remote/file/path'; $bizAttr = 'File attributes'; try { $response = $cos->upload($localFilePath, $bucketName, $cosFilePath, $bizAttr); $code = $response->code; $fileUrl = $response->data->access_url; } catch (jerrayQCloudCosExceptionsRequestException $e) { $response = $e->getBody(); $httpMessage = $e->getMessage(); $httpCode = $e->getCode(); } catch (Exception $e) { // ... }

分片上传(超过一定大小的文件需要使用分片上传)

// response为最后一片的响应,与完整上传结构相同 $response = $cos->uploadSlice($localFilePath, $bucketName, $cosFilePath, $bizAttr);

查询文件

$response = $cos->queryFile($bucketName, $cosFilePath);

更新文件bizAttr

$response = $cos->updateFile($bucketName, $cosFilePath, $bizAttr);

删除文件

$response = $cos->deleteFile($bucketName, $cosFilePath);

下载文件

$result = $cos->downloadFile($bucketName, $cosFilePath, $localFilePath);

目录操作

创建目录

$response = $cos->createFolder($bucketName, 'test/');

目录列表

$limit = 20; // 每页列表数量 $pattern = 'both'; // 显示所有文件和目录 file - 只显示文件;foler - 只显示目录 // direction参数需要配合context参数使用 // context为空时始终取第一页,第一页返回的数据中会含有context参数 // 将此context值传入再次调用,即取到第二页 // direction用来控制翻页方向,next下一页,prev前一页 $context = ''; $direction = 'next'; // 取到第一页 返回当前context为第一页 $response = $cos->listFolder($bucketName, 'test/', $limit, $pattern, $context, $direction); // next 向后翻页,取到第二页,返回当前context为第二页 $response = $cos->listFolder($bucketName, 'test/', $limit, $pattern, $response->data->context, 'next'); // prev 向前翻页,取到第一页,返回当前context为第一页 $response = $cos->listFolder($bucketName, 'test/', $limit, $pattern, $response->data->context, 'prev');

更新目录bizAttr

$response = $cos->updateFolder($bucketName, 'test/');

目录查询

$response = $cos->queryFolder($bucketName, 'test/');

删除目录

注意:目录不为空时会删除失败并抛出 jerrayQCloudCosExceptionsClientException 异常

$response = $cos->deleteFolder($bucketName, 'test/');

Exceptions

接口请求异常

接口返回4xx错误时,抛出 jerrayQCloudCosExceptionsClientException。 返回5xx错误时, 抛出 jerrayQCloudCosExceptionsServerException。 这两个异常均继承自 jerrayQCloudCosExceptionsRequestException

运行时异常

涉及到本地文件读取的接口,如果本地文件不存在或读取失败,会抛出 jerrayQCloudCosExceptionsFileNotFoundException。 创建实例时,如果传入的自定义存储(参数store,可选参数)没有实现 jerrayQCloudCosContractsStore 接口, 抛出 jerrayQCloudCosExceptionsInvalidStoreInstance 。 这两个异常均继承自 jerrayQCloudCosExceptionsRuntimeException

License

MIT

版权声明:

1、该文章(资料)来源于互联网公开信息,我方只是对该内容做点评,所分享的下载地址为原作者公开地址。
2、网站不提供资料下载,如需下载请到原作者页面进行下载。
3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考学习用!
4、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。