HTTP 400:附加到Azure blob时的错误请求

时间:2016-05-14 22:17:27

标签: azure azure-storage-blobs

尝试将字节附加到Azure存储中的附加blob时,我收到HTTP 400错误请求。 Azure存储帐户已存在。

Azure文档仅对AppendText()方法进行了示例调用,但此方法包含有关将此方法与多个客户端编写器一起使用的警告。因此,我想使用AppendBlock()方法来确保调用是原子的。

var cred = new StorageCredentials("storageaccountname", "storageaccountkey");
var account = new CloudStorageAccount(cred, true);

var client = account.CreateCloudBlobClient();
var container = client.GetContainerReference("csharp");
container.CreateIfNotExists();

var log = container.GetAppendBlobReference("artofshell.log");
var stream = new MemoryStream(1024);
var text = System.Text.Encoding.ASCII.GetBytes("Log entry #1");
stream.Write(text, 0, text.Length);

log.CreateOrReplace();
log.AppendBlock(stream);

任何可能导致此问题的想法?

  • Windows 10 Enterprise Insider Build 14332
  • Visual Studio 2015
  • WindowsAzure.Storage library 7.0.1-preview

1 个答案:

答案 0 :(得分:1)

要解决此问题,请在致电AppendBlock()之前重置流的位置。所以你的代码是:

        log.CreateOrReplace();
        stream.Position = 0;//Reset stream's position
        log.AppendBlock(stream);

您收到此错误的原因是您尝试发送0个字节。由于流位于末尾,因此您尝试发送的内容的长度为0,而存储服务并不喜欢它:)。当我运行你的代码并在Fiddler中跟踪请求/响应时,我得到了400错误以及以下详细信息:

<?xml version="1.0" encoding="utf-8"?>
    <Error>
        <Code>InvalidHeaderValue</Code>
        <Message>
            The value for one of the HTTP headers is not in the correct format.
            RequestId:b265553a-0001-0072-6e58-ae8e34000000
            Time:2016-05-15T03:15:51.0349150Z
        </Message>
        <HeaderName>
            Content-Length
        </HeaderName>
        <HeaderValue>
            0
        </HeaderValue>
    </Error>