У меня есть служба WCF ... которая будет находиться на Azure. Я добавил проверки подлинности форм и авторизации с помощью следующей конфигурации в файле web.config:Звонки на службу Wcf запрещены? Это проблема с веб-конфигурацией?
<system.web>
<compilation debug="true" targetFramework="4.0" />
<authentication mode="Forms">
<forms loginUrl="blah.svc" timeout="2880" />
</authentication>
<membership defaultProvider="SqlMembershipProvider">
<providers>
<add connectionStringName="blah" applicationName="blah_app" name="SqlMembershipProvider" type="System.Web.Security.SqlMembershipProvider" />
</providers>
</membership>
<profile>
<providers>
<add name="SqlProfileProvider" type="System.Web.Profile.SqlProfileProvider" connectionStringName="blah" applicationName="blah_app" />
</providers>
</profile>
<roleManager enabled="true" defaultProvider="SqlRoleProvider">
<providers>
<add connectionStringName="blah" applicationName="blah_app" name="SqlRoleProvider" type="System.Web.Security.SqlRoleProvider" />
</providers>
</roleManager>
</system.web>
<system.serviceModel>
<behaviors>
<serviceBehaviors>
<behavior name="wsHttp">
<serviceMetadata httpGetEnabled="true" />
<serviceDebug includeExceptionDetailInFaults="false" />
<serviceAuthorization principalPermissionMode="UseAspNetRoles" roleProviderName="SqlRoleProvider" />
<serviceCredentials>
<serviceCertificate x509FindType="FindBySubjectName" storeName="My" storeLocation="LocalMachine" findValue="blah_cert" />
</serviceCredentials>
</behavior>
</serviceBehaviors>
</behaviors>
<serviceHostingEnvironment multipleSiteBindingsEnabled="true" />
<services>
<service name="blah_app.blah" behaviorConfiguration="wsHttp">
<endpoint address="" contract="blah_app.iblah" binding="wsHttpBinding" />
</service>
</services>
</system.serviceModel>
Проблема я получаю то, что любой из обращений к веб-сервиса от клиента пришедшего в Denied!
public class Blah:IBlah
{
[PrincipalPermission(SecurityAction.Demand, Role = "BlahOppRole")]
public BlahResponse Blah(BlahRequest BlahRequest)
{
BlahResponse = new BlahResponse();
return response;
}
}
Мой клиент - приложение для консолей Windows. Он имеет следующую конфигурацию:
<system.serviceModel>
<bindings>
<wsHttpBinding>
<binding name="WSHttpBinding_IBlah" closeTimeout="00:01:00"
openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00"
bypassProxyOnLocal="false" transactionFlow="false" hostNameComparisonMode="StrongWildcard"
maxBufferPoolSize="524288" maxReceivedMessageSize="65536"
messageEncoding="Text" textEncoding="utf-8" useDefaultWebProxy="true"
allowCookies="false">
<readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
maxBytesPerRead="4096" maxNameTableCharCount="16384" />
<reliableSession ordered="true" inactivityTimeout="00:10:00"
enabled="false" />
<security mode="Message">
<transport clientCredentialType="Digest" proxyCredentialType="None"
realm="" />
<message clientCredentialType="UserName" negotiateServiceCredential="true"
algorithmSuite="Default" />
</security>
</binding>
</wsHttpBinding>
</bindings>
<client>
<endpoint address="http://127.0.0.1:89/Blah.svc"
binding="wsHttpBinding" bindingConfiguration="WSHttpBinding_IBlah"
contract="Data.Blah" name="WSHttpBinding_IBlah">
<identity>
<dns value="blah_cert"/>
</identity>
</endpoint>
</client>
Я проверил, чтобы убедиться, что текущий пользователь имеет «BlahOppRole» и имеет достаточное имя пользователя и пароль через этот WAT (Инструмент администрирования веб-сайтов). Однако неважно, что я делаю, я получаю ответ на отказ от доступа! Любая помощь будет оценена! – bleepzter
Вы можете получить доступ к .svc с IE? –
Когда я запускаю его изнутри, я могу получить к нему доступ. Я вижу экран, где говорится: «Вы создали службу. Для проверки этого вам нужно будет создать клиента ... и т. Д.». Так да. Я всегда обновляю ссылку на услугу у своего клиента, и все в порядке.Однако пользователь не получает разрешение на вызов конкретного метода на основе настроенных ролей, поэтому у меня проблема – bleepzter