更改.net成员身份ConnectionString

时间:2014-01-14 13:16:07

标签: asp.net web-config

我需要更改.net Membership API使用的连接字符串。 基本上,API会在您第一次调用时从app.config加载连接字符串。

有谁知道如何动态告诉API使用不同的连接字符串?

<system.web>
<membership defaultProvider="SqlProvider">
  <providers>
    <clear />
    <add name="SqlProvider" type="System.Web.Security.SqlMembershipProvider" connectionStringName="MySqlConnection"
         enablePasswordRetrieval="false" enablePasswordReset="true" requiresQuestionAndAnswer="false" requiresUniqueEmail="false"
         passwordFormat="Hashed" maxInvalidPasswordAttempts="6545"
         minRequiredPasswordLength="4" minRequiredNonalphanumericCharacters="0"
         passwordAttemptWindow="10" passwordStrengthRegularExpression=""/>
  </providers>
</membership>
<roleManager enabled="true" defaultProvider="RoleProvider">
  <providers>
    <add name="RoleProvider"
         type="System.Web.Security.SqlRoleProvider"
         connectionStringName="MySqlConnection" />
  </providers>
</roleManager>
</system.web>
<connectionStrings>
  <add name="MySqlConnection"
       connectionString=".." 
       providerName="System.Data.SqlClient" />
</connectionStrings> 

编辑:

解决 - &gt; Set connection string of membership dynamically from code

1 个答案:

答案 0 :(得分:0)

您需要创建自己的自定义成员资格提供程序代码(这并不像听起来那么复杂)。您需要提供一个继承自SqlMembershipProvider的类,然后添加一个覆盖初始化方法:

public override void Initialize(string name, System.Collections.Specialized.NameValueCollection config)
{
    // Get your new connnection string name and then overwrite the base here:
    config.Item["connectionStringName"] = "MyNewConnectionStringName";

    base.Initilize(name, config);
}

然后在您的web.config中,对于Membership部分,您需要将新的自定义类型放在'type'属性中。这需要您从ConnectionStrings应用程序部分获取新的连接字符串。

您可能还需要根据您的要求覆盖RoleProvider和ProfileProvider。

P.S。代码在VB.net上快速翻译,如果有一些语法错误,请道歉。


在web.config中,您必须完全限定自定义引用,例如(从评论中查询):

<add name="AspNetSqlMembershipProvider" 
type="zTester.tempMemebership, zTester, Version=1.0.0.0, Culture=neutral" ... etc