123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166 |
- /*
- * Copyright (C) Alibaba Cloud Computing
- * All rights reserved.
- *
- * 版权所有 (C)阿里云计算有限公司
- */
- using System;
- using System.Collections.Generic;
- using System.Globalization;
- using System.Text;
- using Aliyun.OSS.Util;
- namespace Aliyun.OSS
- {
- /// <summary>
- /// 指定从OSS下载Object的请求参数。
- /// </summary>
- public class GetObjectRequest
- {
- private readonly IList<string> _matchingETagConstraints = new List<string>();
- private readonly IList<string> _nonmatchingEtagConstraints = new List<string>();
- private readonly ResponseHeaderOverrides _responseHeaders = new ResponseHeaderOverrides();
- /// <summary>
- /// 获取或设置<see cref="Bucket" />的名称。
- /// </summary>
- public string BucketName { get; private set; }
- /// <summary>
- /// 获取或设置要下载<see cref="OssObject" />的Key。
- /// </summary>
- public string Key { get; private set; }
- /// <summary>
- /// 获取表示请求应当返回<see cref="OssObject" />内容的字节范围。
- /// </summary>
- /// <remarks>
- /// 调用<see cref="SetRange" />方法进行设置,如果没有设置,则返回null。
- /// </remarks>
- public long[] Range { get; private set; }
- /// <summary>
- /// 获取或设置“If-Unmodified-Since”参数。
- /// </summary>
- /// <remarks>
- /// 该参数表示:如果传入参数中的时间等于或者晚于文件实际修改时间,则传送文件;
- /// 如果早于实际修改时间,则返回错误。
- /// </remarks>
- public DateTime? UnmodifiedSinceConstraint { get; set; }
- /// <summary>
- /// 获取或设置“If-Modified-Since”参数。
- /// </summary>
- /// <remarks>
- /// 该参数表示:如果指定的时间早于实际修改时间,则正常传送文件,并返回 200 OK;
- /// 如果参数中的时间和实际修改时间一样或者更晚,会返回错误。
- /// </remarks>
- public DateTime? ModifiedSinceConstraint { get; set; }
- /// <summary>
- /// 获取一个列表表示:如果传入期望的ETag和<see cref="OssObject" />的ETag匹配,则正常的发送文件。
- /// 如果不符合,返回错误。
- /// 对应“If-Match”参数,
- /// </summary>
- public IList<string> MatchingETagConstraints
- {
- get { return _matchingETagConstraints; }
- }
- /// <summary>
- /// 获取一个列表表示:如果传入期望的ETag和<see cref="OssObject" />的ETag不匹配,则正常的发送文件。
- /// 如果符合,返回错误。
- /// 对应“If-None-Match”参数,
- /// </summary>
- public IList<string> NonmatchingETagConstraints
- {
- get { return _nonmatchingEtagConstraints; }
- }
- /// <summary>
- /// 获取的返回请求头重载<see cref="ResponseHeaderOverrides" />实例。
- /// </summary>
- public ResponseHeaderOverrides ResponseHeaders
- {
- get { return _responseHeaders; }
- }
- /// <summary>
- /// 构造一个新的<see cref="GetObjectRequest" />实例。
- /// </summary>
- /// <param name="bucketName"><see cref="OssObject" />所在<see cref="Bucket" />的名称。</param>
- /// <param name="key"><see cref="OssObject" />的<see cref="P:OssObject.Key" />。</param>
- public GetObjectRequest(string bucketName, string key)
- {
- BucketName = bucketName;
- Key = key;
- }
- /// <summary>
- /// 设置一个值表示请求应当返回Object内容的字节范围(可选)。
- /// </summary>
- /// <param name="start">
- /// 范围的起始值。
- /// <para>
- /// 当值大于或等于0时,表示起始的字节位置。
- /// 当值为-1时,表示不设置起始的字节位置,此时end参数不能-1,
- /// 例如end为100,Range请求头的值为bytes=-100,表示获取最后100个字节。
- /// </para>
- /// </param>
- /// <param name="end">
- /// 范围的结束值,应当小于内容的字节数。(最大为内容的字节数-1)
- /// <para>
- /// 当值小于或等于0时,表示结束的字节位或最后的字节数。
- /// 当值为-1时,表示不设置结束的字节位置,此时start参数不能为-1,
- /// 例如start为99,Range请求头的值为bytes=99-,表示获取第100个字节及
- /// 以后的所有内容。
- /// </para>
- /// </param>
- public void SetRange(long start, long end)
- {
- Range = new[] { start, end };
- }
- /// <summary>
- /// 添加Header值
- /// </summary>
- /// <param name="headers">添加完Header之后的最终Header</param>
- internal void Populate(IDictionary<string, string> headers)
- {
- if (Range != null && (Range[0] >= 0 || Range[1] >= 0))
- {
- var rangeHeaderValue = new StringBuilder();
- rangeHeaderValue.Append("bytes=");
- if (Range[0] >= 0)
- rangeHeaderValue.Append(Range[0].ToString(CultureInfo.InvariantCulture));
- rangeHeaderValue.Append("-");
- if (Range[1] >= 0)
- rangeHeaderValue.Append(Range[1].ToString(CultureInfo.InvariantCulture));
- headers.Add(HttpHeaders.Range, rangeHeaderValue.ToString());
- }
- if (ModifiedSinceConstraint != null)
- {
- headers.Add(OssHeaders.GetObjectIfModifiedSince,
- DateUtils.FormatRfc822Date(ModifiedSinceConstraint.Value));
- }
- if (UnmodifiedSinceConstraint != null)
- {
- headers.Add(OssHeaders.GetObjectIfUnmodifiedSince,
- DateUtils.FormatRfc822Date(UnmodifiedSinceConstraint.Value));
- }
- if (_matchingETagConstraints.Count > 0)
- {
- headers.Add(OssHeaders.GetObjectIfMatch,
- OssUtils.JoinETag(_matchingETagConstraints));
- }
- if (_nonmatchingEtagConstraints.Count > 0)
- {
- headers.Add(OssHeaders.GetObjectIfNoneMatch,
- OssUtils.JoinETag(_nonmatchingEtagConstraints));
- }
- }
- }
- }
|