更新时间:2024-04-30 gmt 08:00
设置对象属性-j9九游会登录
开发过程中,您有任何问题可以在github上,或者在中发帖求助。接口参考文档详细介绍了每个接口的参数和使用方法。
您可以在上传对象时设置对象属性。对象属性包含对象长度、对象mime类型、对象md5值(用于校验)、对象存储类型、对象自定义元数据。对象属性可以在多种上传方式下(文本上传、流式上传、文件上传、分段上传),或时进行设置。
对象属性详细说明见下表:
|
名称 |
描述 |
默认值 |
|---|---|---|
|
对象长度(content-length) |
上传对象的长度,超过流/文件的长度会截断。 |
流/文件实际长度 |
|
对象mime类型(content-type) |
对象的mime类型,定义对象的类型及网页编码,决定浏览器将以什么形式、什么编码读取对象。 |
binary/octet-stream |
|
对象md5值(content-md5) |
对象数据的md5值(经过base64编码),提供给obs服务端,校验数据完整性。 |
无 |
|
对象存储类型 |
对象的存储类型,不同的存储类型可以满足客户业务对存储性能、成本的不同诉求。默认与桶的存储类型保持一致,可以设置为与桶的存储类型不同。 |
无 |
|
对象自定义元数据 |
用户对上传到桶中对象的自定义属性描述,以便对对象进行自定义管理。 |
无 |
设置对象长度
// 引入依赖库
require 'vendor/autoload.php';
// 使用源码安装时引入sdk代码库
// require 'obs-autoloader.php';
// 声明命名空间
use obs\obsclient;
// 创建obsclient实例
$obsclient = new obsclient ( [
//推荐通过环境变量获取aksk,这里也可以使用其他外部引入方式传入,如果使用硬编码可能会存在泄露风险。
//您可以登录访问管理控制台获取访问密钥ak/sk,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
'key' => getenv('access_key_id'),
'secret' => getenv('secret_access_key'),
'endpoint' => 'https://your-endpoint'
] );
$resp = $obsclient->putobject([
'bucket' => 'bucketname',
'key' => 'objectname',
'sourcefile' => 'localfile', // localfile为上传的本地文件路径,需要指定到具体的文件名
'contentlength' => 1024 * 1024 // 1mb
]);
printf("requestid:%s\n",$resp['requestid']);
使用contentlength参数指定对象长度。
设置对象mime类型
// 引入依赖库
require 'vendor/autoload.php';
// 使用源码安装时引入sdk代码库
// require 'obs-autoloader.php';
// 声明命名空间
use obs\obsclient;
// 创建obsclient实例
$obsclient = new obsclient ( [
//推荐通过环境变量获取aksk,这里也可以使用其他外部引入方式传入,如果使用硬编码可能会存在泄露风险。
//您可以登录访问管理控制台获取访问密钥ak/sk,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
'key' => getenv('access_key_id'),
'secret' => getenv('secret_access_key'),
'endpoint' => 'https://your-endpoint'
] );
$resp = $obsclient->putobject([
'bucket' => 'bucketname',
'key' => 'objectname.jpg',
'sourcefile' => 'localimage.jpg',
'contenttype' => 'image/jpeg'
]);
printf("requestid:%s\n",$resp['requestid']);
- 使用contenttype参数指定对象mime类型。
- 如果不设置对象mime类型,sdk会根据上传对象的后缀名自动判断对象mime类型,如.xml判断为application/xml文件;.html判断为text/html文件。
设置对象md5值
// 引入依赖库
require 'vendor/autoload.php';
// 使用源码安装时引入sdk代码库
// require 'obs-autoloader.php';
// 声明命名空间
use obs\obsclient;
// 创建obsclient实例
$obsclient = new obsclient ( [
//推荐通过环境变量获取aksk,这里也可以使用其他外部引入方式传入,如果使用硬编码可能会存在泄露风险。
//您可以登录访问管理控制台获取访问密钥ak/sk,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
'key' => getenv('access_key_id'),
'secret' => getenv('secret_access_key'),
'endpoint' => 'https://your-endpoint'
] );
$resp = $obsclient->putobject([
'bucket' => 'bucketname',
'key' => 'objectname',
'body' => 'hello obs'
// your md5 which should be encoded by base64
'contentmd5' => base64_encode(hash("md5", "hello obs!", true))
]);
printf("requestid:%s\n",$resp['requestid']);
- 使用contentmd5参数指定对象md5值。
- 对象数据的md5值必须经过base64编码。
- obs服务端会将该md5值与对象数据计算出的md5值进行对比,如果不匹配则上传失败,返回http 400错误。
- 如果不设置对象的md5值,obs服务端会忽略对对象数据的md5值校验。
设置对象存储类型
// 引入依赖库
require 'vendor/autoload.php';
// 使用源码安装时引入sdk代码库
// require 'obs-autoloader.php';
// 声明命名空间
use obs\obsclient;
// 创建obsclient实例
$obsclient = new obsclient ( [
//推荐通过环境变量获取aksk,这里也可以使用其他外部引入方式传入,如果使用硬编码可能会存在泄露风险。
//您可以登录访问管理控制台获取访问密钥ak/sk,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
'key' => getenv('access_key_id'),
'secret' => getenv('secret_access_key'),
'endpoint' => 'https://your-endpoint'
] );
$resp = $obsclient->putobject([
'bucket' => 'bucketname',
'key' => 'objectname',
'sourcefile' => 'localfile',
// 设置对象存储类型为归档存储
'storageclass' => obsclient::storageclasscold
]);
printf("requestid:%s\n",$resp['requestid']);
- 使用storageclass参数指定对象的存储类型。
- 如果不设置,对象的存储类型默认与桶的存储类型保持一致。
- 对象的存储类型分为三类,其含义与一致。
- 下载归档存储类型的对象前必须将其恢复。
设置对象自定义元数据
// 引入依赖库
require 'vendor/autoload.php';
// 使用源码安装时引入sdk代码库
// require 'obs-autoloader.php';
// 声明命名空间
use obs\obsclient;
// 创建obsclient实例
$obsclient = new obsclient ( [
//推荐通过环境变量获取aksk,这里也可以使用其他外部引入方式传入,如果使用硬编码可能会存在泄露风险。
//您可以登录访问管理控制台获取访问密钥ak/sk,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
'key' => getenv('access_key_id'),
'secret' => getenv('secret_access_key'),
'endpoint' => 'https://your-endpoint'
] );
$resp = $obsclient->putobject([
'bucket' => 'bucketname',
'key' => 'objectname',
'sourcefile' => 'localfile',
'metadata' => ['property1' => 'property-value1', 'property2' => 'property-value2']
]);
printf("requestid:%s\n",$resp['requestid']);
- 使用metadata参数指定对象自定义元数据。
- 在上面设置对象自定义元数据示例代码中,用户自定义了一个名称为“property1”,值为“property-value1”的元数据和一个名称为“property2”,值为“property-value2”的元数据。
- 一个对象可以有多个元数据,总大小不能超过8kb。
- 对象的自定义元数据可以通过obsclient->getobjectmetadata获取,参见获取对象元数据。
- 使用obsclient->getobject下载对象时,对象的自定义元数据也会同时下载。
父主题:
相关文档
意见反馈
文档内容是否对您有帮助?
提交成功!非常感谢您的反馈,我们会继续努力做到更好!
您可在查看反馈及问题处理状态。
系统繁忙,请稍后重试
如您有其它疑问,您也可以通过华为云社区问答频道来与我们联系探讨