0

我正在尝试使用 Visual Studio 2010 构建需要 x509 证书才能在 C# 中的 Windows Azure 上部署的 Healthvault WCF Web 服务。当我在本地 IIS7 上调试解决方案时,我可以毫无问题地执行所有功能。当我部署到 Windows Azure 并尝试运行我的任何方法时,我收到此错误。

服务器在处理请求时遇到错误。异常消息是“访问被拒绝。”。有关更多详细信息,请参阅服务器日志。异常堆栈跟踪是:

在 System.ServiceModel.Dispatcher.SyncMethodInvoker.Invoke(对象实例,Object[] 输入,Object[]& 输出)在 System.ServiceModel.Dispatcher.DispatchOperationRuntime.InvokeBegin(MessageRpc& rpc) 在 System.ServiceModel.Dispatcher.ImmutableDispatchRuntime.ProcessMessage5( MessageRpc& rpc) 在 System.ServiceModel.Dispatcher.ImmutableDispatchRuntime.ProcessMessage31(MessageRpc& rpc) 在 System.ServiceModel.Dispatcher.MessageRpc.Process(Boolean isOperationContextSet)

这似乎与 Healthvault 代码没有任何关系,所以我假设它与 WCF 服务有关。我无法弄清楚我的本地开发环境和 Azure 之间有什么变化。无论如何,这是我的 web.config 文件

<?xml version="1.0"?>
<configuration>
  <system.diagnostics>
    <trace>
      <listeners>
        <add type="Microsoft.WindowsAzure.Diagnostics.DiagnosticMonitorTraceListener, Microsoft.WindowsAzure.Diagnostics, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
          name="AzureDiagnostics">
          <filter type="" />
        </add>
      </listeners>
    </trace>
  </system.diagnostics>
  <system.web>
    <compilation debug="true" targetFramework="4.0" />
  </system.web>
 <system.serviceModel>
   <services>
     <service name="myIHM.Healthvault">
       <endpoint address="" binding="webHttpBinding" contract="myIHM.IHealthvault" behaviorConfiguration="webHttp" />
     </service>
   </services>
    <behaviors>
      <serviceBehaviors>
        <behavior>
          <!-- To avoid disclosing metadata information, set the value below to false and remove the metadata endpoint above before deployment -->
          <serviceMetadata httpGetEnabled="true"/>
          <!-- To receive exception details in faults for debugging purposes, set the value below to true.  Set to false before deployment to avoid disclosing exception information -->
          <serviceDebug includeExceptionDetailInFaults="true"/>
        </behavior>
      </serviceBehaviors>
      <endpointBehaviors>
        <behavior name="webHttp">
          <webHttp/>
        </behavior>
      </endpointBehaviors>
    </behaviors>
    <serviceHostingEnvironment multipleSiteBindingsEnabled="true" />
  </system.serviceModel>
  <system.webServer>
    <modules runAllManagedModulesForAllRequests="true"/>
  </system.webServer>
  <appSettings>
    <add key="ApplicationId" value="[my-app-id]"/>
    <add key="ShellUrl" value="https://account.healthvault-ppe.com/"/>
    <add key="HealthServiceUrl" value="https://platform.healthvault-ppe.com/platform/"/>
    <add key="AppCertSubject" value="[my-cert-subject]"/>
  </appSettings>
</configuration>

我四处寻找一些答案,但似乎找不到任何与我的情况有关的东西。有人有什么建议吗?谢谢。

4

1 回答 1

0

需要注意的一件事是,在开发结构中运行时,您比在云结构中运行时拥有更多权限。因此,在开发结构中工作然后在云中遇到权限错误的情况并不少见;真可惜,我知道。您可以尝试使用免费试用的Azure 诊断管理器 ( http://www.cerebrata.com/Products/AzureDiagnosticsManager/Default.aspx ) 获取服务器日志。这可能会为您提供有关失败原因的更多详细信息。

于 2010-07-26T22:58:20.153 回答