在 Windows 窗体 C# 中更新密码
本文关键字:更新 密码 Windows 窗体 | 更新日期: 2023-09-27 18:36:26
我正在用C#创建登录应用程序(Windows Forms),并将.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个文本框和一个按钮 - 即:-
文本框1-->当前密码
文本框2-->新密码
文本框3-->确认新密码
按钮-->更新密码
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"]);
}
}
但是上面的代码没有更新密码。如何更正上面的代码?所以它完美地工作。
请指导我。
DataRow dRow1 = ds2.Tables["UserData"].NewRow();
dRow1[1] = ConfirmNewPassword.Text;
ds2.Tables["UserData"].Rows.Add(dRow1);
UpdateDB();
您要在UpdateUsrPassword_Click
中添加一行,但不应该更新现有行吗?
你应该做:
- 从数据库获取实际密码
- 更新包含实际密码的现有行
而不是添加一行,你应该使用这样的东西:
dataSet1.Tables["Customers"].Rows[4]["CompanyName"] = "Updated Company Name";
这将更新数据集中的值,然后可以将其推送回数据库。
有关编辑数据集中的值的详细信息的源:
https://msdn.microsoft.com/en-us/library/tat996zc.aspx