Я пытаюсь найти ошибку в моей конфигурации wcf, но я не могу найти, где проблема. Уместно, мне нужно еще пару глаз; в любом случае я хочу использовать выборочную сертификацию сертификации в wcf. Я установил точку останова в моем классе CertificateValidator, но этот пункт прерывания не поймал никакого запроса, но приложение запущено, и я могу отправлять запросы (без сертификата).Проверка подлинности сертификата Wcf не подтверждается
Вот моя конфигурация
<system.serviceModel>
<bindings>
<basicHttpBinding>
<binding maxReceivedMessageSize="104857600">
<security>
<message clientCredentialType="Certificate" />
</security>
</binding>
</basicHttpBinding>
</bindings>
<services>
<service name="AccountService" behaviorConfiguration="">
<endpoint address="" binding="basicHttpBinding" bindingConfiguration="" contract="IAccountService"></endpoint>
</service>
<service name="PortalService" behaviorConfiguration="">
<endpoint address="" binding="basicHttpBinding" bindingConfiguration="" contract="IPortalService"></endpoint>
</service>
</services>
<behaviors>
<serviceBehaviors>
<behavior>
<serviceMetadata httpGetEnabled="true" httpsGetEnabled="true"/>
<serviceDebug includeExceptionDetailInFaults="false"/>
<serviceCredentials>
<clientCertificate>
<authentication certificateValidationMode="Custom" customCertificateValidatorType="Services.Validators.CertificateValidator, Services" />
</clientCertificate>
</serviceCredentials>
</behavior>
</serviceBehaviors>
</behaviors>
<protocolMapping>
<add binding="basicHttpsBinding" scheme="https" />
</protocolMapping>
<serviceHostingEnvironment aspNetCompatibilityEnabled="true" multipleSiteBindingsEnabled="true" />
</system.serviceModel>
Здравствуйте Колин, спасибо за ваш ответ, я попробовал, но без эффекта.Вы просто добавляете имя привязки и устанавливаете это имя для служб, не так ли? Или есть что-то, чего я пропустил? –
Посмотрите, если это вам больше –
Эй, Колин поблагодарил вас за добавление советов к вашему ответу, все, что вы упоминаете, правильно, и я могу просто добавить в этот список «добавить идентификатор к конечной точке (я думаю, что это требует базовыйHttpBinding)». Самая большая ошибка, которую я сделал, - это думать, что использовать услугу только для проверки сообщений от клиента до обслуживания, поэтому я пропустил . Очевидно, WCF не может проверять сообщение только в одном направлении. Но, что вы упомянули, прежде чем я пропустил имена в некоторых элементах, я думал, что .net будет использовать спецификацию по умолчанию без имени ... Во всяком случае, я думаю, что ваш ответ правильный и полезный. –