我在本地计算机上进行了用户名/密码验证,使用自签名证书,一切正常,但是当我将我的应用程序放在IIS 7.5和Windows Server 2008 R2上时,它给了我错误:
找不到与绑定WSHttpBinding的端点的scheme http匹配的基址。已注册的基地址方案为[https]。
我的网络服务cfg:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<system.serviceModel>
<behaviors>
<serviceBehaviors>
<behavior name="ServiceCredentialsBehavior">
<serviceCredentials>
<serviceCertificate findValue="cn=AmicCert" storeName="Root" storeLocation="LocalMachine" />
<userNameAuthentication userNamePasswordValidationMode="Custom" customUserNamePasswordValidatorType="Util.CustomUserNameValidator, Util" />
</serviceCredentials>
<serviceMetadata httpGetEnabled="true" />
</behavior>
</serviceBehaviors>
</behaviors>
<services>
<service behaviorConfiguration="ServiceCredentialsBehavior" name="Service">
<endpoint address="" binding="wsHttpBinding" bindingConfiguration="MessageAndUserName" name="SecuredByTransportEndpoint" contract="IService" />
</service>
</services>
<bindings>
<wsHttpBinding>
<binding name="MessageAndUserName">
<security mode="Message">
<message clientCredentialType="UserName" />
</security>
</binding>
</wsHttpBinding>
</bindings>
<client />
</system.serviceModel>
<system.web>
<compilation debug="true" />
</system.web>
</configuration>
答案 0 :(得分:13)
听起来您正在托管的IIS网站实例仅配置为HTTPS(SSL)。右键单击网站实例,然后选择“编辑绑定...”。你看到那里列出了端口80(普通HTTP)吗?另外,请检查“SSL设置”功能,确保未启用“始终需要”选项。
答案 1 :(得分:10)
如果您不想为端点使用HTTPS / SSL,那么Drew的回答是正确的。
如果您确实想在端点上使用SSL,则需要更改:
<security mode="Message">
为:
<security mode="TransportWithMessageCredential">
答案 2 :(得分:1)
要使其工作并且仍然要求IIS需要SSL,您需要在配置文件中对端点进行一些更改:使用https(address
将https://...
属性设置为服务的地址)和listenUri
属性到服务的地址http(http://...
)。这适用于wsHttp
和basicHttp
。