Я пытаюсь использовать настраиваемые ASP.NET MembershipProvider и RoleProvider для обеспечения безопасности моей службы. Служба размещается в консольном приложении, а не в IIS. Я использую webHttpBinding с базовой аутентификацией. Я настроил serviceCredentials и serviceAuthorization для использования провайдеров. Провайдеры действительно инициализируются. Но WCF, похоже, игнорирует мои настройки и пытается войти в систему в Windows. Я понял это из журнала событий и подтвердил, отправив свои учетные данные Windows в службу. Ниже вы можете увидеть мои скриншоты конфигурации и отладки. Почему для авторизации используются окна? Может быть, без IIS невозможно использовать провайдеры аутентификации ASP.NET?
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<system.web>
<roleManager
enabled="true"
defaultProvider="CustomRoleProvider">
<providers>
<clear/>
<add
name="CustomRoleProvider"
type="CustomRoles.CustomRoleProvider, CustomRoles"/>
</providers>
</roleManager>
<membership defaultProvider="CustomMembershipProvider" userIsOnlineTimeWindow="15">
<providers>
<clear/>
<add name="CustomMembershipProvider"
type="CustomRoles.CustomMembershipProvider, CustomRoles"/>
</providers>
</membership>
</system.web>
<system.serviceModel>
<bindings>
<webHttpBinding>
<binding name="webHttp">
<security mode="TransportCredentialOnly">
<transport clientCredentialType="Basic" />
</security>
</binding>
</webHttpBinding>
</bindings>
<behaviors>
<serviceBehaviors>
<behavior name="Service">
<serviceAuthorization principalPermissionMode="UseAspNetRoles"
roleProviderName="CustomRoleProvider" />
<serviceCredentials>
<userNameAuthentication userNamePasswordValidationMode="MembershipProvider"
membershipProviderName="CustomMembershipProvider" />
</serviceCredentials>
<serviceSecurityAudit auditLogLocation="Application" serviceAuthorizationAuditLevel="SuccessOrFailure"
messageAuthenticationAuditLevel="SuccessOrFailure" />
</behavior>
</serviceBehaviors>
</behaviors>
<services>
<service behaviorConfiguration="Service" name="CustomRoles.Service">
<endpoint address="http://127.0.0.1:8060" binding="webHttpBinding"
bindingConfiguration="webHttp" contract="CustomRoles.IService" />
</service>
</services>
</system.serviceModel>
</configuration>
Вот что я вижу при отладке. Почему для авторизации используются окна?
экран учетных данных http://img81.imageshack.us/img81/1289/credentials.gif < / а>