限定条件下载
开发过程中,您有任何问题可以在github上提交issue,或者在华为云对象存储服务论坛中发帖求助。接口参考文档详细介绍了每个接口的参数和使用方法。
下载对象时,可以指定一个或多个限定条件,满足限定条件时则进行下载,否则返回异常码,下载对象失败。
您可以使用的限定条件如下:
参数 |
作用 |
格式 |
---|---|---|
IfModifiedSince |
如果对象在指定的时间后有修改,则返回对象内容,否则返回错误。 |
符合http://www.ietf.org/rfc/rfc2616.txt规定格式的HTTP时间字符串。 |
IfUnmodifiedSince |
如果对象在指定的时间后没有修改,则返回对象内容,否则返回错误。 |
符合http://www.ietf.org/rfc/rfc2616.txt规定格式的HTTP时间字符串。 |
IfMatch |
如果对象的ETag值与该参数值相同,则返回对象内容,否则抛出异常。 |
字符串。 |
IfNoneMatch |
如果对象的ETag值与该参数值不相同,则返回对象内容,否则抛出异常。 |
字符串。 |
- 对象的ETag值是指对象数据的MD5校验值。
- 如果包含IfUnmodifiedSince并且不符合或者包含IfMatch并且不符合,则下载对象失败,抛出异常中HTTP状态码为:412 precondition failed。
- 如果包含IfModifiedSince并且不符合或者包含IfNoneMatch并且不符合,则下载对象失败,抛出异常中HTTP状态码为:304 Not Modified。
以下代码展示了如何进行限定条件下载:
// 引入依赖库 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', 'signature' => 'obs' ] ); $resp = $obsClient -> getObject([ 'Bucket' => 'bucketname', 'Key' => 'objectname', 'IfModifiedSince' => 'Thu, 31 Dec 2015 16:00:00 GMT' ]); printf("RequestId:%s\n", $resp['RequestId']); printf("Object Content:\n"); echo $resp ['Body'];