Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 770227
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 14, 20262026-05-14T18:27:53+00:00 2026-05-14T18:27:53+00:00

I’m currently working on a membership system for my web application, which is based

  • 0

I’m currently working on a membership system for my web application, which is based on forms authentication from the framework.

I created some users with the integrated tool, and the login is perfectly working. But now what I want to do is to give administrator the capability to create, modify, delete users.

So here is what I’ve got right now:

Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
    Dim muc As MembershipUserCollection = Membership.GetAllUsers()

    ComboBox1.DataSource = muc
    ComboBox1.DataValueField = "UserName"
    ComboBox1.DataTextField = "UserName"
    ComboBox1.DataBind()
End Sub

Protected Sub ComboBox1_SelectedIndexChanged(ByVal sender As Object, ByVal e As EventArgs) Handles ComboBox1.SelectedIndexChanged

    Dim userName As String = ComboBox1.SelectedValue

    Dim mu As MembershipUser = Membership.GetUser(userName)

    Dim userRoles As String() = Roles.GetRolesForUser(userName)

    tbComments.Text = mu.Comment
    tbEmail.Text = mu.Email
    lblUserName.Text = mu.UserName
End Sub

Protected Sub Button1_Click(ByVal sender As Object, ByVal e As EventArgs) Handles Button1.Click
    Dim userName As String = ComboBox1.SelectedValue
    Dim mu As MembershipUser = Membership.GetUser(userName)

    If Not mu Is Nothing Then
        Try
            mu.Comment = tbComments.Text
            Membership.UpdateUser(mu)

            mu.Email = tbEmail.Text
            Membership.UpdateUser(mu)

            mu.IsApproved = True
            Membership.UpdateUser(mu)

            mu = Nothing
        Catch ex As Exception
            Console.WriteLine(ex.ToString())
        End Try
    End If

    DetailPanel.Visible = False
End Sub

The problem is that the record doesn’t seem to be updated in the database.
I made the multiple calls to Membership.UpdateUser after reading this blog entry, but it didn’t change anything.

A strange thing I noticed while debugging, is that when I enter the Button1_Click method, Membership.GetUser(userName) returns me values from my precedent attempt ! I don’t really understand what I’m missing.

Does someone have a clue ?

Thanks in advance !

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-14T18:27:54+00:00Added an answer on May 14, 2026 at 6:27 pm

    First:

    The blog entry you cite is just wrong.

    Here is the method you are calling, tell me if you see an indication that it needs to be called multiple times to update multiple properties:

    public override void UpdateUser(MembershipUser user)
    {
        if (user == null)
        {
            throw new ArgumentNullException("user");
        }
        SecUtility.CheckParameter(ref user.UserName, true, true, true, 0x100, "UserName");
        string email = user.Email;
        SecUtility.CheckParameter(ref email, this.RequiresUniqueEmail, this.RequiresUniqueEmail, false, 0x100, "Email");
        user.Email = email;
        try
        {
            SqlConnectionHolder connection = null;
            try
            {
                connection = SqlConnectionHelper.GetConnection(this._sqlConnectionString, true);
                this.CheckSchemaVersion(connection.Connection);
                SqlCommand command = new SqlCommand("dbo.aspnet_Membership_UpdateUser", connection.Connection);
                command.CommandTimeout = this.CommandTimeout;
                command.CommandType = CommandType.StoredProcedure;
                command.Parameters.Add(this.CreateInputParam("@ApplicationName", SqlDbType.NVarChar, this.ApplicationName));
                command.Parameters.Add(this.CreateInputParam("@UserName", SqlDbType.NVarChar, user.UserName));
                command.Parameters.Add(this.CreateInputParam("@Email", SqlDbType.NVarChar, user.Email));
                command.Parameters.Add(this.CreateInputParam("@Comment", SqlDbType.NText, user.Comment));
                command.Parameters.Add(this.CreateInputParam("@IsApproved", SqlDbType.Bit, user.IsApproved ? 1 : 0));
                command.Parameters.Add(this.CreateInputParam("@LastLoginDate", SqlDbType.DateTime, user.LastLoginDate.ToUniversalTime()));
                command.Parameters.Add(this.CreateInputParam("@LastActivityDate", SqlDbType.DateTime, user.LastActivityDate.ToUniversalTime()));
                command.Parameters.Add(this.CreateInputParam("@UniqueEmail", SqlDbType.Int, this.RequiresUniqueEmail ? 1 : 0));
                command.Parameters.Add(this.CreateInputParam("@CurrentTimeUtc", SqlDbType.DateTime, DateTime.UtcNow));
                SqlParameter parameter = new SqlParameter("@ReturnValue", SqlDbType.Int);
                parameter.Direction = ParameterDirection.ReturnValue;
                command.Parameters.Add(parameter);
                command.ExecuteNonQuery();
                int status = (parameter.Value != null) ? ((int) parameter.Value) : -1;
                if (status != 0)
                {
                    throw new ProviderException(this.GetExceptionText(status));
                }
            }
            finally
            {
                if (connection != null)
                {
                    connection.Close();
                    connection = null;
                }
            }
        }
        catch
        {
            throw;
        }
    }
    

    Second:

    You are rebinding your list every postback. This needs to be done only once and the list is stored in viewstate.

    Here is a working implementation:

    UpdateUser.aspx

    <%@ Page Language="vb" %>
    
    <script runat="server">
    
        Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
    
            ' be sure that DropDownList1.AutoPostBack = true
    
            If Not IsPostBack Then
                BindUserList()
            End If
        End Sub
    
    
        Private Sub ComboBox1_SelectedIndexChanged(ByVal sender As Object, ByVal e As EventArgs) Handles ComboBox1.SelectedIndexChanged
            DisplayDetails(ComboBox1.SelectedValue)
        End Sub
    
    
        Private Sub Button1_Click(ByVal sender As Object, ByVal e As EventArgs) Handles Button1.Click
            Dim approved As Boolean = True
            Dim username As String = ComboBox1.SelectedValue
            Dim comments As String = tbComments.Text
            Dim email As String = tbEmail.Text
    
            UpdateUser(username, approved, comments, email)
        End Sub
    
        Private Sub BindUserList()
            '' you only need to databind once, the datasource is stored in viewstate
            Dim muc As MembershipUserCollection = Membership.GetAllUsers()
    
            ComboBox1.DataSource = muc
            ComboBox1.DataValueField = "UserName"
            ComboBox1.DataTextField = "UserName"
            ComboBox1.DataBind()
            '' initialize the selection
            ComboBox1_SelectedIndexChanged(ComboBox1, EventArgs.Empty)
        End Sub
    
    
        Private Sub DisplayDetails(ByVal userName As String)
            Dim mu As MembershipUser = Membership.GetUser(userName)
    
            Dim userRoles As String() = Roles.GetRolesForUser(userName)
    
            tbComments.Text = mu.Comment
            tbEmail.Text = mu.Email
            lblUserName.Text = mu.UserName
        End Sub
    
        Private Sub UpdateUser(ByVal userName As String, ByVal approved As Boolean, ByVal comments As String, ByVal email As String)
            Dim mu As MembershipUser = Membership.GetUser(userName)
            If Not mu Is Nothing Then
                Try
    
                    mu.Comment = comments
                    mu.Email = email
                    mu.IsApproved = approved
    
                    Membership.UpdateUser(mu)
    
                    ErrLabel.Text = ""
                Catch ex As Exception
                    ErrLabel.Text = ex.Message
                End Try
            End If
        End Sub
    </script>
    
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head runat="server">
        <title></title>
    </head>
    <body>
        <form id="form1" runat="server">
        <div>
            <asp:DropDownList ID="ComboBox1" runat="server" AutoPostBack="True">
            </asp:DropDownList>
        </div>
        <p>
            UserName:<asp:Label ID="lblUserName" runat="server" Text=""></asp:Label><br />
            Email:<asp:TextBox ID="tbEmail" runat="server"></asp:TextBox><br />
            Comments:<asp:TextBox ID="tbComments" runat="server"></asp:TextBox><br />
        </p>
        <asp:Button ID="Button1" runat="server" Text="Update" Height="26px" Width="61px" /><br />
        <asp:Label ID="ErrLabel" runat="server" Text=""></asp:Label>
        </form>
    </body>
    </html>
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.