我希望得到富有成效的答案。我应该如何将 web.config 中为 asp.net 成员提供的设置移动到数据库中以进行跨应用程序自定义。例如成员(member)信息包括如下
<providers>
<add
name="OdbcProvider"
type="Samples.AspNet.Membership.OdbcMembershipProvider"
connectionStringName="OdbcServices"
enablePasswordRetrieval="true"
enablePasswordReset="true"
requiresQuestionAndAnswer="true"
writeExceptionsToEventLog="true" />
</providers>
</membership>
额外
.NET 2.0
ASP.NET 2.0
相关
moving asp.net membership specific settings to a separate config file
最佳答案
是的,你可以!我们已经成功地做到了这一点。
您可以通过几种方式做到这一点,一种是将您需要的任何属性注入(inject)到提供程序的实例中(此示例假设您正在使用 SqlMembershipProvider
并展示了如何注入(inject)连接字符串,但您可以查看 OdbcMembershipProvider
的源代码以了解自己在哪里执行此操作):
public static void InjectConnectionStringIntoSqlMembershipProvider(SqlMembershipProvider provider, string connectionString) {
Type t = typeof(SqlMembershipProvider);
FieldInfo fi = t.GetField("_sqlConnectionString", BindingFlags.NonPublic | BindingFlags.Instance);
if (fi == null) throw new InvalidOperationException("Invalid private identifier.");
fi.SetValue(provider, connectionString);
}
或者,您可以通过创建一个继承 MembershipProvider
的类来创建您自己的提供者。
或者,正如来自@Andomar 的链接所建议的,您可以从 MembershipProvider
的任何实现(例如 SqlMembershipProvider
等)继承,以获得您想要的。
多年来,我们根据需要定制的程度完成了这三项工作。
关于c# - 将 asp.net 成员资格 web.config 设置移动到数据库这甚至可能吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8257028/