2

目前,在我们的一台客户端机器中,有一个 Wcf 服务作为 Windows 服务托管,实际上目前这正在使用正常的 http 调用。由于我们需要使用 https 而不是 http,因此我们修改了 app.config 但在启动服务后 https url 不起作用。然后我们尝试使用netsh http add urlacl url=https://+:18732/Peripheral/ user=Everyone. .

我们在 URl 浏览器中遇到错误 •确保启用了 TLS 和 SSL 协议。

这与任何证书问题有关吗?如果是这样,我们如何能够解决这个问题?

web.config 如下所示:-

<system.serviceModel>
<standardEndpoints />
  <serviceHostingEnvironment aspNetCompatibilityEnabled="true"/>
  <bindings>
    <basicHttpBinding>
    <binding name ="soapBinding">
    <security mode="Transport">
    <transport clientCredentialType="None"/>
    </security>
    </binding>
    </basicHttpBinding>
    <webHttpBinding>
 <binding name="Bind1" crossDomainScriptAccessEnabled="true">
<security mode="Transport">
 <transport clientCredentialType="None"/>
</security>
</binding>
</webHttpBinding>  
    </bindings>
    <services>
      <service name="Peripheral.Server.Impl.PeripheralServiceImpl" behaviorConfiguration="SvcBhvr">
<host>
<baseAddresses>
  <add baseAddress="https://localhost:18732/Peripheral/" />
  </baseAddresses>
</host>
<endpoint address="https://localhost:18732/Peripheral/" binding="webHttpBinding" behaviorConfiguration="EndPBhvr" bindingConfiguration="Bind1" 
contract="Peripheral.Server.Contract.IPeripheralService">
 <!--<identity>
    <dns value="localhost" />
  </identity>-->
</endpoint>
<endpoint address="mex" binding="mexHttpsBinding" contract="IMetadataExchange" />
</service>
</services>
<behaviors>
<endpointBehaviors>
<behavior name="EndPBhvr">
<webHttp /> 
</behavior>
</endpointBehaviors>
<serviceBehaviors>
<behavior name="SvcBhvr">
<serviceMetadata httpsGetEnabled="true" httpGetEnabled="false" />
<serviceDebug includeExceptionDetailInFaults="true" />
</behavior>
</serviceBehaviors>
</behaviors>
</system.serviceModel>

任何人都知道如何解决这个问题以及我们需要做什么,以便我们能够从 Windows 服务以 https 的形式访问 URL?

4

1 回答 1

6

您可能还需要根据操作系统版本使用 netsh 或 HttpConfig 工具将 ssl 证书绑定到特定端口号。详细说明可以在这里找到

在您的情况下,它可能是:

netsh http add sslcert ipport=0.0.0.0:18732 certhash=<certhash> appid={<guid>} clientcertnegotiation=enable

在哪里

certash = 您的证书指纹(X509Certificate2.Thumbprint)

appid = 可能只是 Guid.NewId()

于 2013-09-02T20:11:34.157 回答