設置對象標簽后,您可以根據需要獲取Object的標簽信息。當存儲空間(Bucket)已開啟版本控制時,OSS默認只獲取Object當前版本的標簽信息,您可以通過指定Object的版本ID(versionId)來獲取Object指定版本的標簽信息。
對象標簽使用一組鍵值對(Key-Value)來標記對象。關于對象標簽的更多信息,請參見對象標簽。
關于獲取對象標簽的更多信息,請參見GetObjectTagging。
注意事項
本文以華東1(杭州)外網Endpoint為例。如果您希望通過與OSS同地域的其他阿里云產品訪問OSS,請使用內網Endpoint。關于OSS支持的Region與Endpoint的對應關系,請參見OSS訪問域名、數據中心、開放端口。
本文以OSS域名新建OSSClient為例。如果您希望通過自定義域名、STS等方式新建OSSClient,請參見新建OssClient。
要獲取對象標簽,您必須具有
oss:GetObjectTagging
權限。具體操作,請參見為RAM用戶授權自定義的權限策略。
獲取Object標簽信息
當存儲空間(Bucket)未開啟版本控制時,您可以根據需要獲取Object標簽信息。當Bucket已開啟版本控制時,OSS默認只獲取Object當前版本標簽信息。
以下代碼用于獲取目標存儲空間examplebucket中exampledir目錄下的exampleobject.txt文件的標簽信息。
<?php
if (is_file(__DIR__ . '/../autoload.php')) {
require_once __DIR__ . '/../autoload.php';
}
if (is_file(__DIR__ . '/../vendor/autoload.php')) {
require_once __DIR__ . '/../vendor/autoload.php';
}
use OSS\Credentials\EnvironmentVariableCredentialsProvider;
use OSS\OssClient;
use OSS\CoreOssException;
// 從環境變量中獲取訪問憑證。運行本代碼示例之前,請確保已設置環境變量OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET。
$provider = new EnvironmentVariableCredentialsProvider();
// yourEndpoint填寫Bucket所在地域對應的Endpoint。以華東1(杭州)為例,Endpoint填寫為https://oss-cn-hangzhou.aliyuncs.com。
$endpoint = "yourEndpoint";
// 填寫Bucket名稱,例如examplebucket。
$bucket = "examplebucket";
// 填寫Object完整路徑,例如exampledir/exampleobject.txt。Object完整路徑中不能包含Bucket名稱。
$object = "exampledir/exampleobject.txt";
$config = array(
"provider" => $provider,
"endpoint" => $endpoint,
"signatureVersion" => OssClient::OSS_SIGNATURE_VERSION_V4,
"region"=> "cn-hangzhou"
);
$ossClient = new OssClient($config);
try {
// 獲取對象標簽。
$config = $ossClient->getObjectTagging($bucket, $object);
printf($object." tags are:".$config->serializeToXml(). "\n");
} catch (OssException $e) {
printf($e->getMessage() . "\n");
return;
}
獲取Object指定版本標簽信息
當Bucket已開啟版本控制時,通過指定Object的版本ID(versionId),您可以獲取Object指定版本標簽信息。
以下代碼用于獲取目標存儲空間examplebucket中exampledir目錄下的exampleobject.txt文件指定版本的標簽信息。
關于獲取versionId的更多信息,請參見列舉文件。
<?php
if (is_file(__DIR__ . '/../autoload.php')) {
require_once __DIR__ . '/../autoload.php';
}
if (is_file(__DIR__ . '/../vendor/autoload.php')) {
require_once __DIR__ . '/../vendor/autoload.php';
}
use OSS\Credentials\EnvironmentVariableCredentialsProvider;
use OSS\OssClient;
use OSS\CoreOssException;
// 從環境變量中獲取訪問憑證。運行本代碼示例之前,請確保已設置環境變量OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET。
$provider = new EnvironmentVariableCredentialsProvider();
// yourEndpoint填寫Bucket所在地域對應的Endpoint。以華東1(杭州)為例,Endpoint填寫為https://oss-cn-hangzhou.aliyuncs.com。
$endpoint = "yourEndpoint";
// 填寫Bucket名稱,例如examplebucket。
$bucket = "examplebucket";
// 填寫Object完整路徑,例如exampledir/exampleobject.txt。Object完整路徑中不能包含Bucket名稱。
$object = "exampledir/exampleobject.txt";
// 填寫Object的版本ID。
$options = array(
'versionId'=>'CAEQMxiBgICAof2D0BYiIDJhMGE3N2M1YTI1NDQzOGY5NTkyNTI3MGYyMzJm****'
);
$config = array(
"provider" => $provider,
"endpoint" => $endpoint,
"signatureVersion" => OssClient::OSS_SIGNATURE_VERSION_V4,
"region"=> "cn-hangzhou"
);
$ossClient = new OssClient($config);
try {
// 獲取對象標簽。
$config = $ossClient->getObjectTagging($bucket, $object,$options);
printf($object." tags are:".$config->serializeToXml(). "\n");
} catch (OssException $e) {
printf($e->getMessage() . "\n");
return;
}