【问题标题】:WCF service with Ssl Certificate in Azure emulatorAzure 模拟器中带有 Ssl 证书的 WCF 服务
【发布时间】:2014-11-03 07:40:41
【问题描述】:

我已经使用以下设置了我的云 http://azure.microsoft.com/en-us/documentation/articles/cloud-services-configure-ssl-certificate/

以及使用以下http://msdn.microsoft.com/en-us/library/ms731074%28v=vs.110%29.aspx的网络角色

我的问题是当我使用模拟器时出现错误在这种情况下证书和网站之间存在名称不匹配(127.0.0.1) 有什么办法可以解决。

【问题讨论】:

  • 您的网站是否获得了通配符 SSL?
  • @GauravMantri 我的证书不是通配符,我应该找一个在模拟器中运行它吗?
  • 让我回答一下我们是如何做到的。可能应该会有所帮助。

标签: wcf azure ssl localhost ssl-certificate


【解决方案1】:

因此,您可以采取两种方法:

  1. 为每个环境创建一个单独的云项目 - 这样您就可以为您的开发环境创建一个自签名证书,并忍受证书不受信任的警告。
  2. 为您的应用程序获取通配符证书 - 这是我们为应用程序所采用的方法(以及第一种方法)。基本上,我们采用了通配符 SSL 证书并在我们的应用程序中使用了该证书。然后我们在位于C:\Windows\System32\drivers\etchosts 文件中添加了一个条目,如下所示:

127.0.0.1 dev.cloudportam.com

接下来,我们在开发云项目的 csdef 文件中添加了 hosts 标头。

<Sites>
  <Site name="Web">
    <Bindings>
      <Binding name="Endpoint1" endpointName="Endpoint1" hostHeader="dev.cloudportam.com" />
      <Binding name="Endpoint2" endpointName="SSL" />
    </Bindings>
  </Site>
</Sites>
<Endpoints>
  <InputEndpoint name="Endpoint1" protocol="http" port="8080" />
  <InputEndpoint name="SSL" protocol="https" port="8082" certificate="SSL" />
</Endpoints>

现在当我们启动应用程序时,它会打开https://localhost:8082/,我们只需将地址更改为https://dev.cloudportam.com:8082,一切正常。

【讨论】:

  • 谢谢!让我澄清几件事:1)我的机器上已经安装了 SSL 证书 - 我可以使用这个证书吗?如何? 2)在天蓝色中,与部署一起安装了相同的证书(从秘密存储中获取)-我可以使用它吗?证书是否应该使用部署服务的主机名进行更改/配置? 3)ssl证书用于验证服务器到客户端,握手的另一端呢? - 客户端应该向服务器显示其证书 - 服务器需要验证客户端是否正常
猜你喜欢
  • 2013-08-03
  • 2013-12-03
  • 1970-01-01
  • 1970-01-01
  • 2022-10-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多