Ich habe einen WCF-Dienst, der HTTPS für die Kommunikation und JSON für das Antwortformat verwendet. Ich möchte nicht, dass meine Methoden für irgendjemand verfügbar sind, also ändere ich die Authentifizierung in IIS von anonymen & grundlegenden zu nur grundlegendem.WCF-Authentifizierung über HTTPS
Bisher ist der Browser für Benutzer zu fragen und übergeben, aber ich erhalte die folgenden Fehler:
kann nicht eine Basisadresse finden, die mit der Bindung WebHttpBinding Schema http für den Endpunkt übereinstimmt. Registrierte Basisadressenschemas sind [https].
Was muss ich an meinem Endpunkt ändern, um mit der Authentifizierung arbeiten zu können?
Meine web.config wie folgt aussieht:
<?xml version="1.0"?>
<configuration>
<system.web>
<compilation debug="false" targetFramework="4.0" />
</system.web>
<system.serviceModel>
<bindings>
<webHttpBinding>
<binding name="restBinding">
<security mode="TransportCredentialOnly">
<transport clientCredentialType="Basic" proxyCredentialType="Basic" />
</security>
</binding>
</webHttpBinding>
</bindings>
<services>
<service name="ContactLibrarySecure.ContactLibraryService">
<endpoint address="mex" binding="mexHttpsBinding" bindingConfiguration=""
name="mex" contract="IMetadataExchange" />
<endpoint address="rest" behaviorConfiguration="restBehavior"
binding="webHttpBinding" bindingConfiguration="restBinding"
name="rest" contract="ContactLibrarySecure.IContact" />
<host>
<baseAddresses>
<add baseAddress="https://192.168.1.31/ContactLibrary2.0HTTPS" />
</baseAddresses>
</host>
</service>
</services>
<behaviors>
<endpointBehaviors>
<behavior name="restBehavior">
<webHttp />
</behavior>
</endpointBehaviors>
<serviceBehaviors>
<behavior name="">
<serviceMetadata httpsGetEnabled="true" />
<serviceDebug includeExceptionDetailInFaults="true" />
</behavior>
</serviceBehaviors>
</behaviors>
<serviceHostingEnvironment multipleSiteBindingsEnabled="true" />
</system.serviceModel>
<system.webServer>
<modules runAllManagedModulesForAllRequests="true"/>
</system.webServer>
</configuration>