我正在尝试使用自签名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();
}
}
答案 0 :(得分: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是您在assembly.cs文件中的WCF项目dll的哈希ID,否则在构建项目之前创建一个并包含。
接下来,您定义了一个可以删除的mex端点,并将serviceMetaData元素更改为httpsGetEnabled ="true"
和httpGetEnabled="false"
现在请务必浏览您的服务页面,看看是否正常。
接下来在客户端代码中调用WCF服务之前,您需要执行以下步骤以绕过证书验证检查:
System.Net.ServicePointManager.ServerCertificateValidationCallback = (sender, cert, chain, error) =>
{
return true;
};
使用上述代码的原因是因为您使用的是自签名证书。如果您的证书已由某个受信任的机构颁发,那么您不需要在客户端应用程序中使用上述代码。
答案 1 :(得分:0)
我在服务器端Web.Config文件中更改了WCF服务中的HTTPSEnabled和HTTPEnabled属性,如上所示。 它没有发出“没有端点监听......”的问题,工作正常。 由于网站严格要求SSL,因此HTTPEnabled属性应设置为false。 感谢您在上面发布解决方案。