我正在尝试使用 Daniel Nauck 创建的 PostgreSQL 成员(member)资格提供程序
http://dev.nauck-it.de/projects/aspsqlprovider
用于 ASP.NET Web 应用程序 (C#) 并按照以下说明进行配置
http://dev.nauck-it.de/projects/1/wiki/Install?version=11
我已经使用 nuget 安装了 NpgSQL 和 Membership 提供程序:
Install-Package Npgsql
Install-Package Nauck.PostgreSQLProvider
访问项目配置网站上的“安全”选项卡时,出现以下错误:
我将给定的 SQL 成员资格表添加到我的 postgres 数据库并指定了连接字符串,以及 web.config 文件中的给定配置。
网络配置:
<configuration>
<connectionStrings>
<add name="PostgreSQL" connectionString="Server=localhost;Port=5432;Database=mydb;User Id=postgres;Password=mypassword;Encoding=UNICODE;Sslmode=Prefer;Pooling=true;" />
</connectionStrings>
<system.web>
<compilation debug="true" targetFramework="4.0" />
<membership defaultProvider="PgMembershipProvider">
<providers>
<clear />
<add name="PgMembershipProvider" type="NauckIT.PostgreSQLProvider.PgMembershipProvider" connectionStringName="PostgreSQL" requiresUniqueEmail="true" enablePasswordRetrieval="false" enablePasswordReset="true" requiresQuestionAndAnswer="true" passwordFormat="Hashed" applicationName="AquilaWeb" />
</providers>
</membership>
<roleManager enabled="true" defaultProvider="PgRoleProvider" cacheRolesInCookie="true" cookieName=".AspNetRoles" cookiePath="/" cookieProtection="All" cookieRequireSSL="false" cookieSlidingExpiration="true" createPersistentCookie="false" cookieTimeout="30" maxCachedResults="25">
<providers>
<clear />
<add name="PgRoleProvider" type="NauckIT.PostgreSQLProvider.PgRoleProvider" connectionStringName="PostgreSQL" applicationName="AquilaWeb" />
</providers>
</roleManager>
<profile enabled="true" defaultProvider="PgProfileProvider">
<providers>
<clear />
<add name="PgProfileProvider" type="NauckIT.PostgreSQLProvider.PgProfileProvider" connectionStringName="PostgreSQL" applicationName="AquilaWeb" />
</providers>
<properties>
<add name="FirstName" />
<add name="LastName" />
</properties>
</profile>
<sessionState mode="Custom" customProvider="PgSessionStateStoreProvider">
<providers>
<clear/>
<add name="PgSessionStateStoreProvider" type="NauckIT.PostgreSQLProvider.PgSessionStateStoreProvider" enableExpiredSessionAutoDeletion="true" expiredSessionAutoDeletionInterval="60000" enableSessionExpireCallback="false" connectionStringName="PostgreSQL" applicationName="AquilaWeb" />
</providers>
</sessionState>
</system.web>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="Npgsql" publicKeyToken="5d8b90d52f46fda7" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-2.0.12.0" newVersion="2.0.12.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
</configuration>
最佳答案
您可能想尝试提供程序的 2.0.0 版本。它包含一个错误修复 ASP.NET 4+ 中的托管环境检测
您可以在 NuGet 上获取最新版本。
project wiki 上提供了文档。
关于使用 PostgreSQL 和 dev.nauck.AspSQLProvider 的 ASP.NET 成员资格,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14126772/