本文整理汇总了C#中UserAccount.Update方法的典型用法代码示例。如果您正苦于以下问题:C# UserAccount.Update方法的具体用法?C# UserAccount.Update怎么用?C# UserAccount.Update使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类UserAccount
的用法示例。
在下文中一共展示了UserAccount.Update方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Settings
public ActionResult Settings(NameValueCollection nvc)
{
ViewBag.IsValid = true;
mu = Membership.GetUser();
ua = new UserAccount(Convert.ToInt32(mu.ProviderUserKey));
uad = new UserAccountDetail();
uad.GetUserAccountDeailForUser(Convert.ToInt32(mu.ProviderUserKey));
string enableProfileLogging = Request.Form["enableprofilelogging"];
string emailmessages = Request.Form["emailmessages"];
string showonmap = Request.Form["showonmap"];
string displayAge = Request.Form["displayage"];
string membersOnlyProfile = Request.Form["membersonlyprofile"];
if (!string.IsNullOrEmpty(membersOnlyProfile))
uad.MembersOnlyProfile = true;
else uad.MembersOnlyProfile = false;
if (!string.IsNullOrEmpty(enableProfileLogging))
uad.EnableProfileLogging = true;
else uad.EnableProfileLogging = false;
if (!string.IsNullOrEmpty(displayAge))
uad.DisplayAge = true;
else uad.DisplayAge = false;
if (!string.IsNullOrEmpty(emailmessages))
uad.EmailMessages = true;
else uad.EmailMessages = false;
if (!string.IsNullOrEmpty(showonmap))
uad.ShowOnMap = true;
else uad.ShowOnMap = false;
uad.Set();
string username = Request.Form["username"].Trim();
bool isNewUserName = false;
bool isValidName = false;
try
{
isValidName = !System.Text.RegularExpressions.Regex.IsMatch(@"[A-Za-z][A-Za-z0-9_]{3,14}", username);
}
catch
{
// bad name
isValidName = false;
}
if (mu.UserName != username && isValidName)
{
// TODO: PUT IN ALL THE SAME VALIDATION AS REGISTRATION
isNewUserName = true;
UserAccount newUsername = new UserAccount(username.Replace(":", string.Empty) /* still annoying errors */);
if (newUsername.UserAccountID != 0)
{
ViewBag.IsValid = false;
ModelState.AddModelError("", BootBaronLib.Resources.Messages.AlreadyInUse + ": " + BootBaronLib.Resources.Messages.UserName);
uad = new UserAccountDetail();
uad.GetUserAccountDeailForUser(Convert.ToInt32(mu.ProviderUserKey));
mu = Membership.GetUser();
ViewBag.UserAccountDetail = uad;
ViewBag.Membership = mu;
return View();
}
else
{
if (!Utilities.IsEmail(Request.Form["email"]))
{
ViewBag.IsValid = false;
ModelState.AddModelError("", BootBaronLib.Resources.Messages.Invalid + ": " + BootBaronLib.Resources.Messages.EMail);
return View();
}
else if (Request.Form["email"].Trim() != ua.EMail)
{
ua = new UserAccount(Convert.ToInt32(mu.ProviderUserKey));
ua.EMail = Request.Form["email"];
ua.Update();
}
ua.UserName = username;
ua.Update();
FormsAuthentication.SetAuthCookie(username, false);
ViewBag.IsValid = true;
}
}
else if (!Utilities.IsEmail(Request.Form["email"]))
{
ViewBag.IsValid = false;
ModelState.AddModelError("", BootBaronLib.Resources.Messages.Invalid + ": " + BootBaronLib.Resources.Messages.EMail);
return View();
}
else if (Request.Form["email"].Trim() != ua.EMail)
//.........这里部分代码省略.........
示例2: LogOff
public ActionResult LogOff()
{
if (Membership.GetUser() == null)
{
FormsAuthentication.SignOut();
return RedirectToAction("Index", "Home");
}
ua = new UserAccount(Membership.GetUser().UserName);
ua.IsOnLine = false;
ua.SigningOut = true;
ua.Update();
ua.RemoveCache();
ChatRoomUser cru = new ChatRoomUser();
cru.GetChatRoomUserByUserAccountID(ua.UserAccountID);
cru.DeleteChatRoomUser();
FormsAuthentication.SignOut();
return RedirectToAction("Index", "Home");
}
示例3: LogOn
public ActionResult LogOn(LogOnModel model, string returnUrl)
{
if (ModelState.IsValid)
{
bool remember = Convert.ToBoolean(model.RememberMe);
if (string.IsNullOrWhiteSpace(model.UserName) ||
string.IsNullOrWhiteSpace(model.Password))
{
return View(model);
}
ua = new UserAccount(model.UserName);
if (ua.UserAccountID == 0)
{
ua = new UserAccount();
ua.GetUserAccountByEmail(model.UserName);
if (ua.UserAccountID > 0)
{
// they were stupid and put their email not username
model.UserName = ua.UserName;
}
}
if (Membership.ValidateUser(model.UserName, model.Password))
{
FormsAuthentication.RedirectFromLoginPage(model.UserName, remember);
if (!String.IsNullOrEmpty(returnUrl))
{
return Redirect(returnUrl);
}
else
{
ua = new UserAccount(model.UserName);
if (ua.IsLockedOut)
{
ModelState.AddModelError(string.Empty, BootBaronLib.Resources.Messages.IsLockedOut);
return View(model);
}
ua.LastLoginDate = DateTime.UtcNow;
ua.FailedPasswordAttemptCount = 0;
ua.IsOnLine = true;
ua.SigningOut = false;
ua.Update();
UserAccountDetail uad = new UserAccountDetail();
uad.GetUserAccountDeailForUser(ua.UserAccountID);
//uad.DefaultLanguage = Utilities.GetCurrentLanguageCode();
//uad.Update();
if (!string.IsNullOrWhiteSpace(uad.DefaultLanguage))
{
HttpCookie hc =
new HttpCookie(SiteEnums.CookieName.usersetting.ToString(), uad.DefaultLanguage);
NameValueCollection nvc = new NameValueCollection();
nvc.Add(SiteEnums.CookieValue.language.ToString(), uad.DefaultLanguage);
Utilities.CookieMaker(SiteEnums.CookieName.usersetting, nvc);
Thread.CurrentThread.CurrentUICulture = CultureInfo.CreateSpecificCulture(uad.DefaultLanguage);
Thread.CurrentThread.CurrentCulture = CultureInfo.CreateSpecificCulture(uad.DefaultLanguage);
}
return RedirectToAction("Home", "Account");
}
}
else
{
// it updates as online, make off
ua = new UserAccount(model.UserName);
if (ua.UserAccountID > 0)
{
ua.IsOnLine = false;
ua.SigningOut = true;
ua.Update();
}
}
}
ModelState.AddModelError(string.Empty, BootBaronLib.Resources.Messages.LoginUnsuccessfulPleaseCorrect);
// If we got this far, something failed, redisplay form
return View(model);
}
示例4: UpdateRoles
public ActionResult UpdateRoles(int userAccountID, IEnumerable<string> roleOption)
{
var ua = new UserAccount(userAccountID)
{
IsApproved = (Request.Form["isApproved"] != null),
EMail = Request.Form["email"]
};
ua.Update();
var uad1 = new UserAccountDetail();
uad1.GetUserAccountDeailForUser(ua.UserAccountID);
uad1.EmailMessages = (Request.Form["emailMessages"] != null);
uad1.Update();
UserAccountRole.DeleteUserRoles(userAccountID);
if (roleOption != null)
{
foreach (Role thenewRole in roleOption.Select(newRole => new Role(newRole)))
{
UserAccountRole.AddUserToRole(userAccountID, thenewRole.RoleID);
}
}
if (ua.UserAccountID > 0)
{
ViewBag.SelectedUser = ua;
var uad = new UserAccountDetail();
uad.GetUserAccountDeailForUser(ua.UserAccountID);
ViewBag.UserAccountDetail = uad;
}
LoadAllRoles();
return View("UserManagement");
}
示例5: ForgotPassword
public ActionResult ForgotPassword(string email)
{
UserAccount ua = new UserAccount();
ua.GetUserAccountByEmail(email);
if (ua.UserAccountID == 0)
{
ViewBag.Result = Messages.NotFound;
}
else
{
ua.FailedPasswordAnswerAttemptCount = 0;
ua.FailedPasswordAttemptCount = 0;
ua.IsLockedOut = false;
ua.Update();
mu = Membership.GetUser(ua.UserName);
string newPassword = mu.ResetPassword();
BootBaronLib.Operational.Utilities.SendMail(email, BootBaronLib.Configs.AmazonCloudConfigs.SendFromEmail, Messages.PasswordReset,
Messages.UserName + ": " + ua.UserName + Environment.NewLine +
Environment.NewLine + Messages.NewPassword + ": " + newPassword +
Environment.NewLine +
Environment.NewLine + Messages.SignIn + ": " + BootBaronLib.Configs.GeneralConfigs.SiteDomain);
ViewBag.Result = Messages.CheckYourEmailAndSpamFolder;
}
return View();
}
示例6: UpdateFailureCount
/// <summary>
/// A helper method that performs the checks and updates associated with password failure tracking.
/// </summary>
private void UpdateFailureCount(string username, SiteEnums.MembershipFailureTypes failureType)
{
var eu = new UserAccount(username);
if (eu.UserAccountID == 0) throw new ProviderException(Messages.UnableToUpdateFailureCount);
int failureCount = 0;
if (failureType == SiteEnums.MembershipFailureTypes.password)
{
failureCount = Convert.ToInt32(eu.FailedPasswordAttemptCount);
}
if (failureType == SiteEnums.MembershipFailureTypes.passwordAnswer)
{
failureCount = Convert.ToInt32(eu.FailedPasswordAnswerAttemptCount);
}
if (failureCount == 0)
{
// First password failure or outside of PasswordAttemptWindow.
// Start a new password failure count from 1 and a new window starting now.
if (failureType == SiteEnums.MembershipFailureTypes.password)
{
eu.FailedPasswordAttemptCount = 1;
// eu.FailedPasswordAttemptWindowStart = FromDB.GetUTCDate();
}
if (failureType == SiteEnums.MembershipFailureTypes.passwordAnswer)
{
eu.FailedPasswordAnswerAttemptCount = 1;
// eu.FailedPasswordAnswerAttemptWindowStart = FromDB.GetUTCDate();
}
try
{
eu.Update();
}
catch
{
throw new ProviderException(Messages.UnableToUpdateFailureCountAndWindowStart);
}
}
else
{
if (failureCount++ >= MaxInvalidPasswordAttempts)
{
// Max password attempts have exceeded the failure threshold. Lock out the user.
eu.IsLockedOut = true;
// eu.LastLockoutDate = FromDB.GetUTCDate();
try
{
eu.Update();
}
catch
{
throw new ProviderException(Messages.UnableToLockOutUser);
}
}
else
{
// Max password attempts have not exceeded the failure threshold. Update
// the failure counts. Leave the window the same.
if (failureType == SiteEnums.MembershipFailureTypes.password)
{
eu.FailedPasswordAttemptCount = failureCount;
}
if (failureType == SiteEnums.MembershipFailureTypes.passwordAnswer)
{
eu.FailedPasswordAnswerAttemptCount = failureCount;
}
try
{
eu.Update();
}
catch
{
throw new ProviderException(Messages.UnableToUpdateFailureCount);
}
}
}
}
示例7: ForgotPassword
public ActionResult ForgotPassword(string email)
{
var ua = new UserAccount();
ua.GetUserAccountByEmail(email);
if (ua.UserAccountID == 0)
{
ViewBag.Result = Messages.NotFound;
}
else
{
ua.FailedPasswordAnswerAttemptCount = 0;
ua.FailedPasswordAttemptCount = 0;
ua.Update();
_mu = Membership.GetUser(ua.UserName);
if (_mu != null)
{
string newPassword = _mu.ResetPassword();
_mail.SendMail(AmazonCloudConfigs.SendFromEmail, email, Messages.PasswordReset,
string.Format("{0}: {1}{2}{2}{3}: {4}{2}{2}{5}: {6}",
Messages.UserName, ua.UserName, Environment.NewLine,
Messages.NewPassword, newPassword, Messages.SignIn, GeneralConfigs.SiteDomain));
}
ViewBag.Result = Messages.CheckYourEmailAndSpamFolder;
}
return View();
}
示例8: UpdateUser
/// <summary>
/// Update the underlying end user for this membership user
/// </summary>
/// <param name="user"></param>
public override void UpdateUser(MembershipUser user)
{
var eu = new UserAccount(Convert.ToInt32(user.ProviderUserKey));
if (eu.UserAccountID < 1)
throw new ProviderException(Messages.UpdateUserFailedNoUniqueUserFound);
if (eu.UserAccountID == 0)
return;
eu.Comment = user.Comment;
eu.CreateDate = user.CreationDate;
eu.EMail = user.Email;
eu.IsApproved = user.IsApproved;
eu.IsLockedOut = user.IsLockedOut;
eu.IsOnLine = user.IsOnline;
eu.LastActivityDate = user.LastActivityDate;
eu.LastLockoutDate = user.LastLockoutDate;
eu.LastLoginDate = user.LastLoginDate;
eu.LastPasswordChangedDate = user.LastPasswordChangedDate;
eu.PasswordQuestion = user.PasswordQuestion;
eu.PasswordQuestion = user.ProviderName;
eu.UserName = user.UserName;
eu.Update();
}
示例9: ValidateUser
/// <summary>
/// Confirms that this person can log in,
/// they are approved and not locked out
/// </summary>
/// <param name="username"></param>
/// <param name="password"></param>
/// <returns></returns>
public override bool ValidateUser(string username, string password)
{
bool isValid = false;
username = username.Trim();
password = password.Trim();
if (username == string.Empty || password == string.Empty)
{
return false;
}
var eu = new UserAccount(username);
if (eu.UserAccountID == 0) return false;
if (!eu.IsApproved) return false;
if (eu.IsLockedOut) return false;
if (IsValidPasswordComparison(password, eu.Password))
{
if (eu.IsLockedOut) return isValid;
isValid = true;
eu.IsOnLine = true;
eu.Update();
}
else
{
UpdateFailureCount(username, SiteEnums.MembershipFailureTypes.password);
}
return isValid;
}
示例10: ResetPassword
/// <summary>
/// Same thing as: GetPassword method here
/// </summary>
/// <param name="username"></param>
/// <param name="answer"></param>
/// <returns></returns>
public override string ResetPassword(string username, string answer)
{
if (!EnablePasswordRetrieval) throw new ProviderException(Messages.PasswordRetrievalNotEnabled);
string password = RandomPassword.Generate(8, 10);
var eu = new UserAccount(username);
if (eu.UserAccountID < 1)
throw new ProviderException(Messages.GetPasswordFailedNoUnique);
if (eu.UserAccountID > 0)
{
// this is going to be reset anyway
//if (eu.IsLockedOut)
// throw new MembershipPasswordException("The supplied user is locked out.");
}
else throw new MembershipPasswordException(Messages.TheSuppliedUserNameIsNotFound);
if (RequiresQuestionAndAnswer && !IsValidPasswordAnswerComparison(answer, eu.PasswordAnswer))
{
UpdateFailureCount(username, SiteEnums.MembershipFailureTypes.passwordAnswer);
throw new MembershipPasswordException(Messages.IncorrectPasswordAnswer);
}
if (PasswordFormat == MembershipPasswordFormat.Hashed)
{
// reset the password
eu.IsLockedOut = false;
eu.FailedPasswordAttemptCount = 0;
eu.Password = EncodePassword(password);
eu.Update();
}
if (PasswordFormat == MembershipPasswordFormat.Encrypted)
{
password = UnEncodePassword(eu.Password);
}
return password;
}
示例11: UnlockUser
/// <summary>
/// Clears a lock so that the membership user can be validated.
/// </summary>
/// <returns>true if the membership user was successfully unlocked; otherwise, false.</returns>
/// <param name="userName">The membership user whose lock status you want to clear.</param>
public override bool UnlockUser(string userName)
{
try
{
var eu = new UserAccount(userName);
if (eu.UserAccountID < 1 || eu.UserAccountID == 0) return false;
eu.IsLockedOut = false;
eu.FailedPasswordAnswerAttemptCount = 0;
eu.FailedPasswordAttemptCount = 0;
eu.Update();
return true;
}
catch
{
return false;
}
}
示例12: GetUser
/// <summary>
/// Get the user by name and online status
/// </summary>
/// <param name="username"></param>
/// <param name="userIsOnline"></param>
/// <returns></returns>
public override MembershipUser GetUser(string username, bool userIsOnline)
{
if (string.IsNullOrWhiteSpace(username)) return null;
var eu = new UserAccount(username);
if (eu.UserAccountID == 0) return null;
if (!eu.IsApproved || eu.IsLockedOut) FormsAuthentication.SignOut();
eu.Update();
var mu = GetMembershipUserFromUserAccount(eu);
return mu;
}
示例13: GetPassword
/// <summary>
/// Gets the password for the specified user name from the data source.
/// </summary>
/// <returns>The password for the specified user name.</returns>
/// <param name="username">The user to retrieve the password for.</param>
/// <param name="answer">The password answer for the user.</param>
public override string GetPassword(string username, string answer)
{
if (!EnablePasswordRetrieval) throw new ProviderException("Password Retrieval Not Enabled.");
string password = string.Empty;
var eu = new UserAccount(username);
if (eu.UserAccountID < 1)
throw new ProviderException("Get password failed. No unique user found.");
if (eu.UserAccountID > 0)
{
if (eu.IsLockedOut)
throw new MembershipPasswordException("The supplied user is locked out.");
}
else throw new MembershipPasswordException("The supplied user name is not found.");
if (RequiresQuestionAndAnswer && !IsValidPasswordAnswerComparison(answer, eu.PasswordAnswer))
{
UpdateFailureCount(username, SiteEnums.MembershipFailureTypes.passwordAnswer);
throw new MembershipPasswordException("Incorrect password answer.");
}
if (PasswordFormat == MembershipPasswordFormat.Hashed)
{
// reset the password
// password = Utilities.RandomPassword.Generate();
eu.Password = EncodePassword(password);
eu.Update();
}
if (PasswordFormat == MembershipPasswordFormat.Encrypted)
{
password = UnEncodePassword(eu.Password);
}
return password;
}
示例14: ChangePassword
/// <summary>
/// Change the user's password
/// </summary>
/// <param name="username"></param>
/// <param name="oldPassword"></param>
/// <param name="newPassword"></param>
/// <returns></returns>
public override bool ChangePassword(
string username,
string oldPassword,
string newPassword)
{
var args = new ValidatePasswordEventArgs(username, newPassword, true);
OnValidatingPassword(args);
if (args.Cancel)
{
if (args.FailureInformation != null) throw args.FailureInformation;
throw new MembershipPasswordException("Change password canceled due to new password validation failure.");
}
var eu = new UserAccount(username);
if (eu.UserAccountID < 1) throw new ProviderException("Change password failed. No unique user found.");
if (EncodePassword(oldPassword) != eu.Password)
{
return false;
}
eu.Password = EncodePassword(newPassword);
try
{
return eu.Update();
}
catch
{
return false;
}
}
示例15: GetUser
/// <summary>
/// Get the user by name and online status
/// </summary>
/// <param name="username"></param>
/// <param name="userIsOnline"></param>
/// <returns></returns>
public override MembershipUser GetUser(string username, bool userIsOnline)
{
if (username == string.Empty) { return null; }
MembershipUser mu = null;
UserAccount eu = new UserAccount(username);
if (eu.UserAccountID != 0)// && eu.IsOnLine == userIsOnline)
{
eu.Update(); // updates the last activity date
// get the values for this end user
mu = GetMembershipUserFromUserAccount(eu);
}
return mu;
}