我在我的 ASP .Net 4 Web 应用程序项目中使用 AspNetSqlMembershipProvider。
我在 web.config 文件中将用户地址配置为唯一的(requiresUniqueEmail="true"),如下所示:
<membership>
<providers>
<clear />
<add name="AspNetSqlMembershipProvider"
type="System.Web.Security.SqlMembershipProvider, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"
connectionStringName="MyAuthDB"
enablePasswordRetrieval="false"
enablePasswordReset="true"
requiresQuestionAndAnswer="true"
applicationName="/"
requiresUniqueEmail="true"
minRequiredPasswordLength="6"
minRequiredNonalphanumericCharacters="1"
passwordFormat="Hashed"
maxInvalidPasswordAttempts="5"
passwordAttemptWindow="10" />
</providers>
</membership>
但是,当我使用数据库中已有的电子邮件执行以下代码时,虽然没有将新行添加到 aspnet_Membership 表中,但正在将一个条目添加到:aspnet_Users 和 aspnet_Profile 表中。
有什么办法可以阻止这些条目也被添加到上述两个表中?
这是来自后面代码的代码:
if (Membership.GetUser(EN(this.Id.Value)) != null) {
this.CustomFieldValidatorId.IsValid = false;
}
else {
try {
string username = EN(this.Id.Value);
string password = EN(this.Password.Value);
string email = EN(this.Email.Value);
string question = EN(this.SecurityQuestion.Value);
string answer = EN(this.Answer.Value);
string firstname = EN(this.FirstName.Value);
string lastname = EN(this.LastName.Value);
DateTime birthdate = new DateTime(
Convert.ToInt32(EN(this.BirthYear.SelectedValue)),
Convert.ToInt32(EN(this.BirthMonth.SelectedValue)),
Convert.ToInt32(EN(this.BirthDay.SelectedValue)));
string company = EN(this.Company.Value);
string add1 = EN(this.StreetAddress1.Value);
string add2 = EN(this.StreetAddress2.Value);
string city = EN(this.City.Value);
string state = EN(this.State.Value);
string zip = EN(this.Zip.Value);
string country = EN(this.Country.SelectedValue);
string countrycode = EN(this.CountryCode.Value);
string areacode = EN(this.AreaCode.Value);
string phonenum = EN(this.PhoneNumber.Value);
string extension = EN(this.Extension.Value);
MembershipCreateStatus S;
Membership.CreateUser(username, password, email, question, answer, false, out S);
WebProfile wp = new WebProfile();
wp.Initialize(username, true);
wp.PersonalInformation.FirstName = firstname;
wp.PersonalInformation.LastName = lastname;
wp.PersonalInformation.BirthDate = birthdate;
wp.PersonalInformation.Company = company;
wp.PersonalInformation.StreetAddress1 = add1;
wp.PersonalInformation.StreetAddress2 = add2;
wp.PersonalInformation.City = city;
wp.PersonalInformation.State = state;
wp.PersonalInformation.Zip = zip;
wp.PersonalInformation.Country = country;
wp.PersonalInformation.PhoneCountryCode = countrycode;
wp.PersonalInformation.PhoneAreaCode = areacode;
wp.PersonalInformation.PhoneNumber = phonenum;
wp.PersonalInformation.PhoneExtension = extension;
wp.Save();
MembershipUser user = Membership.GetUser(username);
Roles.AddUserToRole(username, "Developer");
Membership.UpdateUser(user);
EmailDeveloper(firstname, lastname, email, (Guid)user.ProviderUserKey);
this.DeveloperEmail.Text = email;
}
catch (MembershipCreateUserException ex) {
switch (ex.StatusCode) {
case MembershipCreateStatus.DuplicateEmail:
this.CustomFieldValidatorEmail.IsValid = false;
break;
default:
this.CustomFieldValidatorGeneral.ErrorMessage = ex.Message.ToString();
this.CustomFieldValidatorGeneral.IsValid = false;
break;
}
}
}
private string EN(string v) {
return HttpUtility.HtmlEncode(v.Trim());
}