我一直在玩这个一段时间,并且在Blob Storage的任何一个电话都失败了,所以我不会显示我的代码,我会显示我的堆栈跟踪:
[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,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 Storage的每一个呼叫都可以获得403.
>在绝望中,在服务器上安装Azure Powershell只是为了验证与Azure的某种类型的通信是否正常工作.而且工作正常.
>浏览到天蓝色的管理门户,并且工作正常.
有任何想法吗?这应该是使用端口80或443,对吗?所以应该没有办法这样的网络问题.让我知道,如果这是错的.
>工作生产机器是Azure VM(具有IIS 7.5的Server 2008 R2)
服务器也有一些区别:
>这台新机器是物理硬件(Server 2012和IIS 8)
>这是在我的天蓝色订阅中使用不同的存储帐户,但是我已经尝试了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
…容器只是一个容器名称枚举(有几个):
Public Enum Containers CallerWavs CampaignImports Delve Exports CampaignImages logos Reportlogos WebLinkImages End Enum
…是的,他们有大写字符,这会导致问题.一切都出来之前被迫小写.
此外,我确实验证了正确的AzureConnectionString从我的设置类中出来.再次,我尝试了其他一些工作.这个也在其他地方工作!