【问题标题】:Update Password in Windows Form C#在 Windows 窗体 C# 中更新密码
【发布时间】:2013-11-01 03:25:48
【问题描述】:

我正在用 C# 创建登录应用程序(Windows 窗体),并使用 .NET Framework 4.5 和 Visual Studio 2012。

我已经在数据库中手动输入了用户名和密码。

所以在 LoginForm 中,用户输入他们的用户名和密码,我的代码如下:

public partial class LoginForm : Form
{
    public LoginForm()
    {
        InitializeComponent();
    }

    System.Data.SqlServerCe.SqlCeConnection con;
    System.Data.SqlServerCe.SqlCeDataAdapter da;
    DataSet ds1;
    int MaxRows = 0;
    int inc = 0;

    private void go_Click(object sender, EventArgs e)
    {
        DataRow dRow = ds1.Tables["Users"].Rows[inc];
        if (EnterMasterPassword.Text == dRow.ItemArray.GetValue(1).ToString())
        {
            this.DialogResult = DialogResult.OK;
            this.Close();
        }
        else
            MessageBox.Show("Try again");
    }

    private void LoginForm_Load(object sender, EventArgs e)
    {
        con = new System.Data.SqlServerCe.SqlCeConnection();
        con.ConnectionString = "Data Source=C:\\PMDatabase.sdf";
        con.Open();
        ds1 = new DataSet();
        string sql = "SELECT * From tbl_login";
        da = new System.Data.SqlServerCe.SqlCeDataAdapter(sql, con);
        da.Fill(ds1, "Users");
        MaxRows = ds1.Tables["Users"].Rows.Count;
        con.Close();
    }
}

*其中 go 是一个按钮*

这完美地工作并且用户成功登录。但我不知道如何为使用 Windows 窗体的用户提供更新/更改密码功能。如何更新数据库?还有用户名和密码字段吗?

到目前为止,我已经完成了以下程序:

当用户点击“更新密码”按钮时,会打开一个新表单(名称:Form7),其中包含 3 个标签、3 个文本框和一个按钮 - 即: -

TextBox1--> 当前密码

TextBox2--> 新密码

TextBox3--> ConfirmNewPassword

按钮--> UpdateUsrPassword

Form7 的代码如下:-

public partial class Form7 : Form
    {
        public PasswordsAndData()
        {
            InitializeComponent();
        }
        System.Data.SqlServerCe.SqlCeConnection con1;
        System.Data.SqlServerCe.SqlCeDataAdapter da1;
        DataSet ds2;
        int totalPasswords = 0, inc = 0;
        private void Form7_Load(object sender, EventArgs e)
        {
            con1 = new System.Data.SqlServerCe.SqlCeConnection();
            con1.ConnectionString = "Data Source=C:\\PMDatabase.sdf";
            con1.Open();
            ds2 = new DataSet();
            string sql = "SELECT * From tbl_UserData";
            da1 = new System.Data.SqlServerCe.SqlCeDataAdapter(sql, con1);
            da1.Fill(ds2, "UserData");
            totalPasswords = ds2.Tables["UserData"].Rows.Count;
            con1.Close();
        }
        private void UpdateUsrPassword_Click(object sender, EventArgs e)
        {
            if(NewPassword.Text == ConfirmNewPassword.Text)
            {
                DataRow dRow1 = ds2.Tables["UserData"].NewRow();
                dRow1[1] = ConfirmNewPassword.Text;            
                ds2.Tables["UserData"].Rows.Add(dRow1);
                UpdateDB();
                MessageBox.Show("Password Updated");
                totalPasswords++;
                inc = totalPasswords - 1;
            }
        }
        private void UpdateDB()
        {
            System.Data.SqlServerCe.SqlCeCommandBuilder cb1;
            cb1 = new System.Data.SqlServerCe.SqlCeCommandBuilder(da1);
            cb1.DataAdapter.Update(ds2.Tables["UserData"]);
        }
    }

但是上面的代码并没有更新密码。如何更正上面的代码?所以它的工作原理很完美。

请指导我。

【问题讨论】:

  • 附注:如果您继续以纯文本形式将密码保存到数据库中,您的作业将获得负分。
  • 您在运行上述代码时是否遇到任何错误?请显示错误
  • @Alexei Levenkov 加密密码并保存到数据库不是必须的
  • 您正在添加一行。您应该改为更新该行吗?
  • @AlexeiLevenkov 可能不仅用于以明文形式存储密码,还用于在 Form Code-Behind 中访问数据库:P

标签: c# winforms forms passwords


【解决方案1】:
DataRow dRow1 = ds2.Tables["UserData"].NewRow();
dRow1[1] = ConfirmNewPassword.Text;            
ds2.Tables["UserData"].Rows.Add(dRow1);
UpdateDB();

您正在 UpdateUsrPassword_Click 中添加一行,但您不应该更新现有行吗?

你应该这样做:

  1. 从数据库获取实际密码
  2. 更新包含实际密码的现有行

【讨论】:

    【解决方案2】:

    你应该使用这样的东西,而不是添加一行:

    dataSet1.Tables["Customers"].Rows[4]["CompanyName"] = "Updated Company Name";
    

    这会更新数据集中的值,然后您可以将其推送回数据库。

    提供有关在数据集中编辑值的更多信息的来源:

    https://msdn.microsoft.com/en-us/library/tat996zc.aspx

    【讨论】:

      猜你喜欢
      • 2020-03-22
      • 1970-01-01
      • 1970-01-01
      • 2022-08-23
      • 1970-01-01
      • 1970-01-01
      • 2019-06-29
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多