C# 动态修改ProfileBase ConnectionString

C# 动态修改ProfileBase ConnectionString,c#,asp.net,membership-provider,sqlprofileprovider,C#,Asp.net,Membership Provider,Sqlprofileprovider,我有以下代码,我想用它来修改ProfileBaseconnectionString: ProfileBase profile = ProfileBase.Create(username); string _connectionString = (_DataModel.Connection as System.Data.EntityClient.EntityConnection).StoreConnection.ConnectionString; FieldInfo connectionStr

我有以下代码,我想用它来修改
ProfileBase
connectionString:

ProfileBase profile = ProfileBase.Create(username);

string _connectionString = (_DataModel.Connection as System.Data.EntityClient.EntityConnection).StoreConnection.ConnectionString;

FieldInfo connectionStringField = profile.Providers["MySqlProfileProvider"].GetType().BaseType.GetField("_sqlConnectionString", System.Reflection.BindingFlags.Instance | System.Reflection.BindingFlags.NonPublic);
connectionStringField.SetValue(profile.Providers["MySqlProfileProvider"], _connectionString);

profile["FirstName"] = firstName;
profile["Surname"] = surname;

profile.Save();
首先,
connectionStringField
总是返回为null,但是我可以看到,
profile.Providers
确实包含
MySqlProfileProvider
。这是在my
Web.Config
中指定的:

<profile defaultProvider="MySqlProfileProvider">
  <providers>
    <clear/>
    <add name="MySqlProfileProvider" connectionStringName="MyApp" applicationName="MyApp" type="System.Web.Profile.SqlProfileProvider, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"/>
  </providers>
  <properties>
    <add allowAnonymous="false" defaultValue="" name="FirstName" readOnly="false" serializeAs="String" type="System.String"/>
    <add allowAnonymous="false" defaultValue="" name="Surname" readOnly="false" serializeAs="String" type="System.String"/>
  </properties>
</profile>


我的问题是,
connectionStringField
为什么返回为空?这是否意味着我无法通过覆盖其
初始化
方法来修改连接字符串,就像我通常对自定义
成员身份提供程序
所做的那样?

您删除了太多的基类型:

.Providers["MySqlProfileProvider"].GetType()**.BaseType**.GetField
.Providers["MySqlProfileProvider"].GetType().GetField
以下代码应该可以工作:

string _connectionString = (_DataModel.Connection as System.Data.EntityClient.EntityConnection).StoreConnection.ConnectionString;
Type type = profile.Providers["MySqlProfileProvider"].GetType();
FieldInfo connectionStringField = type.GetField("_sqlConnectionString", System.Reflection.BindingFlags.Instance | System.Reflection.BindingFlags.NonPublic);
connectionStringField.SetValue(profile.Providers["MySqlProfileProvider"], _connectionString);

ASP.NET网站或项目模板?@IrishChieftain ASP.NET项目(MVC w/WCF w/EF)。您是否获得了名字和姓氏属性?@IrishChieftain是的,它们都很好,而且一直都是。唯一的问题是,我现在正在尝试更新
profile.Save()之前的连接字符串方法,并且我的code.Fulvio没有成功,如果它与EF相关,我就没有成功。希望有更多知识的人能够回答这个问题。调试时是否能够看到“StoreConnection.ConnectionString”的值?