Ответ 1
Кажется, вы создаете RESTful Service с WCF, и вы действительно близки к его обеспечению.
Вот что вам нужно сделать для его защиты:
- Добавьте новую конфигурацию
WebHttpBinding
, в которой установлен режим безопасностиTransport
. - Назначьте новую конфигурацию
WebHttpBinding
для привязки вашей конечной точки службы. - Убедитесь, что доступ к службе RESTful можно получить только через HTTPS, установив
httpGetEnabled="false"
. - Настройте конечную точку публикации метаданных для использования HTTPS.
Эти изменения суммируются ниже в обновленном файле конфигурации (см. комментарии для измененных точек). Также обратите внимание, что ваша конечная точка обслуживания должна использовать схему HTTPS, а не HTTP.
<system.serviceModel >
<services>
<service name="WcfRestfulService.HttpService"
behaviorConfiguration="ServiceBehaviour" >
<endpoint address=""
binding="webHttpBinding"
<!-- Add reference to secure WebHttpBinding config -->
bindingConfiguration="webHttpTransportSecurity"
behaviorConfiguration="web"
contract="WcfRestfulService.IHttpService" />
<!-- Need to make sure that our metadata
publishing endpoint is using HTTPS as well -->
<endpoint address="mex"
binding="mexHttpsBinding"
contract="IMetadataExchange" />
</service>
<!-- Add secure WebHttpBinding config -->
<bindings>
<webHttpBinding>
<binding name="webHttpTransportSecurity">
<security mode="Transport" />
</binding>
</webHttpBinding>
</bindings>
</services>
<behaviors>
<serviceBehaviors>
<behavior name="ServiceBehaviour">
<serviceMetadata httpsGetEnabled="true"
<!-- Make sure the service can
be accessed only via HTTPS -->
httpGetEnabled="false"/>
<serviceDebug includeExceptionDetailInFaults="false"/>
</behavior>
</serviceBehaviors>
<endpointBehaviors>
<behavior name="web">
<webHttp/>
</behavior>
</endpointBehaviors>
</behaviors>
<serviceHostingEnvironment multipleSiteBindingsEnabled="true"/>
</system.serviceModel>