WebMatrix.WebData не может прочитать информацию о членстве из отдельного приложения ASP.NET

У меня есть существующий проект, который использует ASP.Net, System.Web.Security и WebMatrix.WebData для системы членства. Это приложение, где все пользователи создаются, обновляются и т. Д. И сохраняются в базе данных.

У меня также есть отдельное приложение, представляющее собой простую рабочую роль Azure, которое должно считывать часть информации о членстве из базы данных. Например, мне нужно посмотреть, в каких ролях находится конкретный пользователь. Я ожидал, что в приведенном ниже примере программы будут показаны разные роли - "Администратор", "Менеджер учетных записей" и т. Д., А также для определенных пользователей, которые будут связаны с этими ролями. Я проверил в базе данных, и все ассоциации правильно хранятся в таблицах "webpages_Membership" и т. Д.

Теперь проблема в том, что мое второе приложение не может видеть ни одну из ролей, созданных первым. Я попытался скопировать как можно больше соответствующих параметров конфигурации из первого проекта во второй. я понимаю WebMatrix.WebData поскольку пакет устарел, он включен в Microsoft.AspNet.WebPages.WebDataЯ просто пытался держать все в точности между двумя проектами.

public static void Main()
{
    if (!WebSecurity.Initialized)
    {
        Console.WriteLine("Initializing WebSecurity");
        WebSecurity.InitializeDatabaseConnection("CustomDbContext", "UserProfile", "Id", "Username", autoCreateTables: false);
    }

    using (var db = new CustomDbContext())
    {
        Console.WriteLine("All Roles : {0}", Roles.GetAllRoles().ToString());

        foreach (var user in db.UserProfiles)
        {
            Console.WriteLine("User      : {0}", user.UserName);
            Console.WriteLine("    Roles : {0}", Roles.GetRolesForUser(user.UserName).ToString());
        }
    }

    Console.Read();
}

Packages.config:

<?xml version="1.0" encoding="utf-8"?>
<packages>
  <package id="EntityFramework" version="6.1.3" targetFramework="net461" />
  <package id="Microsoft.AspNet.WebPages.Data" version="2.0.20710.0" targetFramework="net461" />
  <package id="Microsoft.AspNet.WebPages.WebData" version="2.0.20710.0" targetFramework="net461" />
  <package id="CustomDataModels" version="1.0.0" targetFramework="net461" />
  <package id="WebMatrix.WebData" version="2.0.30506.0" targetFramework="net461" />
</packages>

App.config:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <configSections>
    <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
  </configSections>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.6.1" />
  </startup>
  <connectionStrings>
    <add name="CustomDbContext" connectionString="XXX" providerName="System.Data.SqlClient" />
  </connectionStrings>
  <system.web>
    <authentication mode="Forms">
      <forms loginUrl="~/Account/Login" timeout="2880" />
    </authentication>
    <machineKey validationKey="XXX" decryptionKey="XXX" validation="SHA1" decryption="AES" />
    <roleManager enabled="true" defaultProvider="SimpleRoleProvider">
      <providers>
        <clear />
        <add name="SimpleRoleProvider" type="WebMatrix.WebData.SimpleRoleProvider, WebMatrix.WebData" />
      </providers>
    </roleManager>
    <membership defaultProvider="SimpleMembershipProvider">
      <providers>
        <clear />
        <add name="SimpleMembershipProvider" type="WebMatrix.WebData.SimpleMembershipProvider, WebMatrix.WebData" />
      </providers>
    </membership>
  </system.web>
  <runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
      <dependentAssembly>
        <assemblyIdentity name="WebMatrix.Data" publicKeyToken="31bf3856ad364e35" culture="neutral" />
        <bindingRedirect oldVersion="0.0.0.0-1.0.0.0" newVersion="1.0.0.0" />
      </dependentAssembly>
    </assemblyBinding>
  </runtime>
  <entityFramework>
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
    <providers>
      <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
    </providers>
  </entityFramework>
</configuration>

1 ответ

Решение

Ну, это неудобно. Сначала мне не хватало раздела конфигурации из App.config:

<system.web>
  <roleManager enabled="true" defaultProvider="SimpleRoleProvider">
    <providers>
      <clear />
      <add name="SimpleRoleProvider" type="WebMatrix.WebData.SimpleRoleProvider, WebMatrix.WebData" />
    </providers>
  </roleManager>
  <membership defaultProvider="SimpleMembershipProvider">
    <providers>
      <clear />
      <add name="SimpleMembershipProvider" type="WebMatrix.WebData.SimpleMembershipProvider, WebMatrix.WebData" />
    </providers>
  </membership>
</system.web>

В этот момент я проверял содержимое массивов в отладчике и видел их пустыми. Однако после того, как я добавил этот раздел, я прибег к простому чтению консоли и не мог понять, почему я ничего не изменил.

Console.WriteLine("All Roles : {0}", Roles.GetAllRoles().ToString());

Найди что-нибудь не так? Я кратко просматривал выходные данные после каждого внесенного мной изменения, ожидая увидеть изменения в выходных данных, но я смотрел на ссылки на массивы, а не на их фактическое содержимое!

Другие вопросы по тегам