Поставщик ролей членства не работает с настраиваемой строкой подключения?

Помогите плз с одним вопросом. У меня есть членство, настроенное с помощью IIS7, таблицы для него расположены в моей собственной базе данных, созданные с помощью утилиты aspnet_regsql, и я использую настраиваемую строку подключения для доступа к ней.

Это часть web.config, относящаяся к членству:

<connectionStrings>
    <add connectionString="Server=CORESERVER\SQLExpress;Database=Shop;User ID=Tema;Password=Matrix" name="CustomSqlConnection" />
</connectionStrings>
<profile enabled="true">
      <providers>
        <add name="CustomSqlProfileProvider" type="System.Web.Profile.SqlProfileProvider, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" connectionStringName="CustomSqlConnection" />
      </providers>
</profile>
<roleManager defaultProvider="AspNetSqlRoleProvider" enabled="true">
      <providers>
        <add name="CustomSqlRoleProvider" type="System.Web.Security.SqlRoleProvider, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" connectionStringName="CustomSqlConnection" />
      </providers>
</roleManager>
<membership defaultProvider="CustomSqlMemberProvider">
      <providers>
        <add name="CustomSqlMemberProvider" type="System.Web.Security.SqlMembershipProvider, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" connectionStringName="CustomSqlConnection" enablePasswordReset="true" enablePasswordRetrieval="false" passwordFormat="Hashed" requiresQuestionAndAnswer="true" requiresUniqueEmail="true" applicationName="/" maxInvalidPasswordAttempts="10" minRequiredPasswordLength="6" minRequiredNonalphanumericCharacters="0" passwordAttemptWindow="10" passwordStrengthRegularExpression="" />
      </providers>
</membership>
<authentication mode="Forms">
      <forms cookieless="UseCookies" loginUrl="login.aspx" name="WebShopAuthentication" protection="All" timeout="30" path="/" requireSSL="false" defaultUrl="~/admin/default.aspx" />
</authentication>
<authorization>
      <allow users="*" />
</authorization>

И ... Формы авторизации, получение информации о пользователе и его членстве в порядке. Но ... получать роли всегда ЛОЖНО.

MembershipUser userData = Membership.GetUser(HttpContext.Current.User.Identity.Name);    // OK !!! IT IS GREAT :)
var a = new RolePrincipal(HttpContext.Current.User.Identity);
var aa = a.getRoles();  // {string[0]} - EMPTY!!!
var b = Roles.IsUserInRole("Administrator", "Administrator");  // FALSE!!!
var c = Roles.Providers["CustomSqlRoleProvider"].GetAllRoles();  // {string[0]} - EMPTY!!!
var d = Roles.IsUserInRole(HttpContext.Current.User.Identity.Name, "Administrator"); // FALSE!!!
var e = HttpContext.Current.User.IsInRole("Administrator"); // FALSE !!!

ПОЧЕМУ ???

Что я делаю неправильно???


person Anonymous    schedule 18.10.2010    source источник
comment
Извините за глупый вопрос, но вы действительно создали какие-либо роли и назначили их текущему пользователю?   -  person Jakub Konecki    schedule 19.10.2010
comment
На самом деле да. Есть: 1 провайдер с переопределенной строкой подключения, указывающей на мою БД, 4 роли - Администратор, Клиент, Менеджер, Пользователь и 3 пользователя с именами Администратор, Менеджер, Клиент.   -  person Anonymous    schedule 19.10.2010


Ответы (2)


Просто для уточнения ... авторизация работает нормально и правильно использует роли. Другая часть моего web.config:

<location path="Admin">
    <system.web>
      <pages styleSheetTheme="Admin" theme="Admin">
      </pages>
      <authorization>
        <deny users="?" />
        <allow roles="Administrator" />
      </authorization>
    </system.web>
    <appSettings>
      <add key="ThemeName" value="Admin" />
    </appSettings>
</location>

А затем в коде используется:

Membership.ValidateUser(userName.Text, userPassword.Text) // AND IT WORKS - USER IS LOGGED IN
person Anonymous    schedule 18.10.2010

Ответ заключается в том, что я неправильно добавил параметр applicationName в web.config - после добавления я должен перезапустить IIS и, при необходимости, воссоздать роли. Это последняя версия web.config:

<roleManager defaultProvider="CustomSqlRoleProvider" enabled="true">
      <providers>
        <add name="CustomSqlRoleProvider" type="System.Web.Security.SqlRoleProvider, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" connectionStringName="CustomSqlConnection" applicationName="/" />
      </providers>
    </roleManager>
person Anonymous    schedule 19.10.2010