简体   繁体   English

Azure Blob存储下载:服务器无法进行身份验证,但重试时可以

[英]Azure Blob Storage Download : Server failed to authenticate, but ok on retry

I'm having a really ODD problem using the client side azure SDK from my local PC. 我使用本地PC的客户端azure SDK遇到了一个非常奇怪的问题。

Using the CloudBlobClient to upload and delete files works like charm, but when trying to download a file I am getting an authentication exception (403 Forbidden basically). 使用CloudBlobClient上传和删除文件就像魅力一样,但在尝试下载文件时,我收到了一个身份验证异常(基本上是403 Forbidden)。 However, if I retry the same code it works FINE the next time around . 但是,如果我重试相同的代码,它下次运行时会很精细
Does anyone have any idea why??? 有谁知道为什么???

Here is some simplified code that shows the problem: 以下是一些显示问题的简化代码:

    string blobEndpoint = "http://???.blob.core.windows.net";
    string accountName = "???";
    string accountKey = "???";

        while(retry)
        {
            FileStream stream = new FileStream("C:\\temp\\mydownload.jpg", FileMode.Append);

            try
            {
                CloudBlobClient blobClient =
                new CloudBlobClient(new Uri(blobEndpoint), new StorageCredentialsAccountAndKey(accountName, accountKey));

                CloudBlob blob = blobClient.GetBlobReference("documents/drive.png");

                blob.DownloadToStream(stream);

                retry = false;
            }
            catch (Exception ee)
            {
                if (MessageBox.Show(ee.Message.ToString(), "ARGH!", MessageBoxButtons.RetryCancel) != System.Windows.Forms.DialogResult.Retry)
                    retry = false;
            }
            finally
            {
                stream.Flush();
                stream.Close();
            }

        }

The exception being generated is : 生成的异常是:

    Microsoft.WindowsAzure.StorageClient.StorageClientException was unhandled
  Message=Server failed to authenticate the request. Make sure the value of Authorization header is formed correctly including the signature.
  Source=Microsoft.WindowsAzure.StorageClient
  StackTrace:
       at Microsoft.WindowsAzure.StorageClient.Tasks.Task`1.get_Result()
       at Microsoft.WindowsAzure.StorageClient.Tasks.Task`1.Execute()
       at Microsoft.WindowsAzure.StorageClient.RequestWithRetry.RequestWithRetrySyncImpl[TResult](ShouldRetry retryOracle, SynchronousTask`1 syncTask)
       at Microsoft.WindowsAzure.StorageClient.TaskImplHelper.ExecuteSyncTaskWithRetry[TResult](SynchronousTask`1 syncTask, RetryPolicy policy)
       at Microsoft.WindowsAzure.StorageClient.CloudBlob.DownloadToStream(Stream target, BlobRequestOptions options)
       at Microsoft.WindowsAzure.StorageClient.CloudBlob.DownloadToStream(Stream target)
       at TestAzure.Form1.button1_Click(Object sender, EventArgs e) in c:\users\richard.donaldson\documents\visual studio 2010\Projects\TestAzure\TestAzure\Form1.cs:line 41
       at System.Windows.Forms.Control.OnClick(EventArgs e)
       at System.Windows.Forms.Button.OnClick(EventArgs e)
       at System.Windows.Forms.Button.OnMouseUp(MouseEventArgs mevent)
       at System.Windows.Forms.Control.WmMouseUp(Message& m, MouseButtons button, Int32 clicks)
       at System.Windows.Forms.Control.WndProc(Message& m)
       at System.Windows.Forms.ButtonBase.WndProc(Message& m)
       at System.Windows.Forms.Button.WndProc(Message& m)
       at System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
       at System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
       at System.Windows.Forms.NativeWindow.DebuggableCallback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)
       at System.Windows.Forms.UnsafeNativeMethods.DispatchMessageW(MSG& msg)
       at System.Windows.Forms.Application.ComponentManager.System.Windows.Forms.UnsafeNativeMethods.IMsoComponentManager.FPushMessageLoop(IntPtr dwComponentID, Int32 reason, Int32 pvLoopData)
       at System.Windows.Forms.Application.ThreadContext.RunMessageLoopInner(Int32 reason, ApplicationContext context)
       at System.Windows.Forms.Application.ThreadContext.RunMessageLoop(Int32 reason, ApplicationContext context)
       at System.Windows.Forms.Application.Run(Form mainForm)
       at TestAzure.Program.Main() in c:\users\richard.donaldson\documents\visual studio 2010\Projects\TestAzure\TestAzure\Program.cs:line 18
       at System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
       at System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
       at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
       at System.Threading.ThreadHelper.ThreadStart_Context(Object state)
       at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean ignoreSyncCtx)
       at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
       at System.Threading.ThreadHelper.ThreadStart()
  InnerException: System.Net.WebException
       Message=The remote server returned an error: (403) Forbidden.
       Source=System
       StackTrace:
            at System.Net.HttpWebRequest.GetResponse()
            at Microsoft.WindowsAzure.StorageClient.EventHelper.ProcessWebResponseSync(WebRequest req, EventHandler`1 handler, Object sender)
       InnerException: {"The remote server returned an error: (403) Forbidden."}

Hahahaha. 哈哈哈哈。 Gah. 嘎。 I've just changed it to HTTPS and now it works fine. 我刚刚将其更改为HTTPS ,现在它工作正常。 I should probably use SSL anyway so no worries really, but it should work with the HTTP end point non the less 我应该使用SSL ,所以不用担心,但它应该与HTTP端点一起工作

I have run across this issue when using the Windows Azure SDK for PHP as well. 我在使用Windows Azure SDK for PHP时遇到过这个问题。 Did you notice any strange behavior with your app at the time? 您是否注意到当时您的应用有任何奇怪的行为? IE slow response, major network latency, etc IE响应慢,主要网络延迟等

Added: also were you creating multiple connections quickly, like in a loop? 补充:你是否也在快速创建多个连接,比如在循环中?

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM