0

我正在尝试使用自签名 SSL 设置 WCF 服务。

我可以浏览到 HTTPS,它会显示元数据,我可以创建一个服务引用。

但是它抛出了异常:没有https://wserver:442/service1.svc 可以接受该消息的端点监听。

wserver 是我的服务器的名称,但我没有在任何地方使用它,所以我不知道它从哪里得到它?

我的服务器 Webhost.config (我认为问题可能出在哪里)是:

<?xml version="1.0"?>
<configuration>

  <system.web>
    <compilation debug="true" targetFramework="4.0" />
  </system.web>
  <system.serviceModel>
    <bindings>
      <wsHttpBinding>
        <binding name="Binding1">
          <security mode="TransportWithMessageCredential">
            <message clientCredentialType="UserName"/>
          </security>
        </binding>
      </wsHttpBinding>

    </bindings>
    <services>
      <service behaviorConfiguration="ServiceBehavior" name="AutoSenderWCFService.AutoSenderService">
        <endpoint binding="wsHttpBinding" bindingConfiguration="Binding1"
          contract="AutoSenderWCFService.IService1" />
        <endpoint address="mex" binding="mexHttpsBinding" contract="IMetadataExchange" />
      </service>
    </services>

    <behaviors>
      <serviceBehaviors>
        <behavior name="ServiceBehavior">
          <serviceCredentials>

            <userNameAuthentication userNamePasswordValidationMode="Custom"
              customUserNamePasswordValidatorType="AutoSenderWCFService.MyValidator, AutoSenderWCFService"/>

          </serviceCredentials>

          <!-- 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="false"/>
        </behavior>
      </serviceBehaviors>
    </behaviors>
    <serviceHostingEnvironment multipleSiteBindingsEnabled="true" />
  </system.serviceModel>
 <system.webServer>
    <modules runAllManagedModulesForAllRequests="true"/>
  </system.webServer>

</configuration>

或者我在自签名 SSL 上犯了一个错误?

我的客户端只是:

    private void button1_Click(object sender, EventArgs e)
    {

        ServiceReference1.Service1Client client = new ServiceReference1.Service1Client();
        client.ClientCredentials.UserName.UserName = "test";
        client.ClientCredentials.UserName.Password = "testPassword";            
        ServiceReference1.Contact[] test = client.GetDrivers();

    }
}
4

2 回答 2

0

发生这种情况有几个原因。由于您有一个在 443 上运行的默认 https,因此您将端口 442 用于 https 为您的服务。

您是否在端口 442 上执行了有关 https 侦听的任何映射?您可以使用 netsh 命令执行此操作,如下所示:

C:\> netsh http add sslcert ipport=0.0.0.0:442 certhash=6797aea29440de9389bc636e15a35b741d8c22a3 appid={2e80948d-9ae6-42c9-ad33-294929333965}

您的证书哈希需要是指纹 ID,而 appid 是 WCF 项目 dll 的哈希 ID,您将在您的 assembly.cs 文件中创建一个并包含在您构建项目之前。

接下来,您定义了一个 mex 端点,可以将其删除并将您的 serviceMetaData 元素更改为具有httpsGetEnabled ="true"httpGetEnabled="false"

现在确保浏览到您的服务页面,看看是否正常。

接下来在您的客户端代码中调用 WCF 服务之前,您需要执行以下步骤以绕过证书验证检查:

    System.Net.ServicePointManager.ServerCertificateValidationCallback = (sender, cert, chain, error) =>
                                                                             {
                                                                                 return true;
                                                                             };

使用上述代码的原因是因为您使用的是自签名证书。如果您拥有由某个受信任的机构颁发的证书,那么您的客户端应用程序中不需要上述代码。

于 2012-05-18T14:47:56.530 回答
0

如上所示,我在服务器端 Web.Config 文件的 WCF 服务中更改了 HTTPSEnabled 和 HTTPEnabled 属性。它可以正常工作而不会发出“没有端点正在监听...”问题。由于网站严格要求 SSL,因此 HTTPEnabled 属性应设置为 false。感谢您在上面发布解决方案。

于 2015-06-10T16:09:52.523 回答