【问题标题】:403 error in production from WindowsAzure.Storage来自 WindowsAzure.Storage 的生产中出现 403 错误
【发布时间】:2014-05-14 17:30:31
【问题描述】:

我有一个使用 WindowsAzure.Storage API v3 的 WebForms 应用程序。它在开发和一个生产环境中运行良好,但我正在推出一个新实例,任何调用 Azure Blob 存储的代码都会给我一个 403 错误。

我一直在摆弄这个,它在任何调用 Blob 存储时都失败了,所以我不会显示我的代码,而是显示我的堆栈跟踪:

[WebException: The remote server returned an error: (403) Forbidden.]
   System.Net.HttpWebRequest.GetResponse() +8525404
   Microsoft.WindowsAzure.Storage.Core.Executor.Executor.ExecuteSync(RESTCommand`1 cmd, IRetryPolicy policy, OperationContext operationContext) +1541

[StorageException: The remote server returned an error: (403) Forbidden.]
   Microsoft.WindowsAzure.Storage.Core.Executor.Executor.ExecuteSync(RESTCommand`1 cmd, IRetryPolicy policy, OperationContext operationContext) +2996
   Microsoft.WindowsAzure.Storage.Blob.CloudBlobContainer.CreateIfNotExists(BlobContainerPublicAccessType accessType, BlobRequestOptions requestOptions, OperationContext operationContext) +177
   ObsidianData.Azure.Storage.GetContainer(CloudBlobClient client, Containers targetContainer) in D:\Dev\nSource\Obsidian\Source\ObsidianData\Azure\Storage.vb:84
   ObsidianWeb.Leads.HandleListenLink(String fileName, HyperLink link) in D:\Dev\nSource\Obsidian\Source\ObsidianWeb\Bdc\Leads.aspx.vb:188
   ObsidianWeb.Leads.LoadEntity_ContactDetails(BoLead lead) in D:\Dev\nSource\Obsidian\Source\ObsidianWeb\Bdc\Leads.aspx.vb:147
   ObsidianWeb.Leads.LoadEntity(BoLead Lead) in D:\Dev\nSource\Obsidian\Source\ObsidianWeb\Bdc\Leads.aspx.vb:62
   EntityPages.EntityPage`1.LoadEntity() +91
   EntityPages.EntityPage`1.Page_LoadComplete(Object sender, EventArgs e) +151
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +4018

这是我尝试过的...

  • 在此环境中失败的 AzureStorageConnectionString 在生产中肯定有效
  • 其他连接字符串(来自其他有效的生产环境)也在这里得到 403
  • 在一些旧版本的 REST api 中似乎存在时间戳问题(我没有直接使用...),所以我确定时间是正确的,甚至尝试将服务器切换到 UTC 时间。李>
  • 尝试切换 http/https 之间的连接字符串。
  • 升级到最新版本的 API (v3.1)
  • 尝试修改代码以确保对 Azure 存储的每次调用都得到 403。确实如此。
  • 无奈之下,在服务器上安装了 Azure Powershell 只是为了验证与 Azure 的某种类型的通信是否正常。这很好用。
  • 也浏览到了 azure 管理门户,并且工作正常。

有什么想法吗?这应该只是使用端口 80 或 443,对吧?所以这不应该是某种网络问题。让我知道这是否有误。

  • 工作的生产机器是 Azure VM(带有 IIS 7.5 的 Server 2008 R2) 与服务器也有一些区别:
  • 这台新机器是物理硬件(Server 2012 和 IIS 8)
  • 这是在我的 azure 订阅中使用不同的存储帐户,但是我一共尝试了 3 个连接字符串,但它们都不能在这里工作。

更新:有人要求查看代码。好的,我写了一个名为 Azure.Storage 的类,它只是抽象了我的云存储代码。我们对 Storage.Exists 的调用失败了,所以这是该类中感觉相关的部分:

    Public Shared Function Exists(container As Containers, blobName As String) As Boolean
        Dim Dir As CloudBlobContainer = GetContainer(container)
        Dim Blob As CloudBlockBlob = Dir.GetBlockBlobReference(blobName.ToLower())

        Return Blob.Exists()
    End Function

    Private Shared Function GetContainer(client As CloudBlobClient, targetContainer As Containers)
        Dim Container As CloudBlobContainer = client.GetContainerReference(targetContainer.ToString.ToLower())
        Container.CreateIfNotExists()
        Container.SetPermissions(New BlobContainerPermissions() With {.PublicAccess = BlobContainerPublicAccessType.Blob})

        Return Container
    End Function

    Private Shared Function GetCloudBlobClient() As CloudBlobClient
        Dim Account As CloudStorageAccount = CloudStorageAccount.Parse(Settings.Cloud.AzureStorageConnectionString())

        Return Account.CreateCloudBlobClient()
    End Function

...Containers 只是容器名称的枚举(有几个):

 Public Enum Containers
     CallerWavs
     CampaignImports
     Delve
     Exports
     CampaignImages
     Logos
     ReportLogos
     WebLinkImages
 End Enum

...是的,它们有大写字符,这会导致问题。在输出之前,所有内容都被强制小写。

我还验证了正确的 AzureConnectionString 来自我的设置类。再次,我尝试了一些其他地方的工作。这个也可以在其他地方使用!

【问题讨论】:

  • 我不认为你可以发布你的代码吗?
  • 请检查相关服务器上的时钟。如果服务器上的时间与存储服务器上的时间不同步(允许 +/- 15 分钟偏差),您也可能会收到 403 错误。
  • @GauravMantri 检查了,那在我包含在问题中的列表中,但是谢谢。 ;)
  • 您可以尝试的另一件事是获取应该是 WebException 的 InnerException,阅读其响应流以查看有关错误的更多详细信息。
  • @GauravMantri 嗯,我会试试的。你认为这会提供比我在堆栈跟踪中得到的更多吗?

标签: asp.net vb.net azure azure-blob-storage


【解决方案1】:

请检查相关服务器上的时钟。除了不正确的帐号密钥外,如果服务器上的时间与存储服务器上的时间不同步,您也可能会收到 403 错误(允许存在 +/- 15 分钟偏差)。

【讨论】:

  • 原来是这样,我至少检查了两次。也许这就是我凌晨 2 点工作的结果。顺便说一句,我已经使用了你的 Cerebrata 技术,我很喜欢它,谢谢你:)
  • 天啊,我快疯了。这太愚蠢了。为什么它应该返回 403 时差,为什么不至少提供一个有意义的消息,例如“您的请求时间不能被接受”。
【解决方案2】:

我也遇到了这个错误。我的问题是我在 web.config 中打开了动态 IP 安全限制,并且在某些情况下(例如,带有大量图像的页面)下载的文件数量超过了我在 web.config 中定义的最大阈值。

【讨论】:

    【解决方案3】:

    在我的情况下,访问密钥与源代码使用的连接字符串不同。

    因此请尝试重新检查您的 Azure -> [存储帐户名称] -> 访问密钥 -> key1 -> 密钥和连接字符串

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-12-08
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-07-30
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多