- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我无法将输入的用户名和密码与数据库中指定用户的用户名和密码进行比较。我相信所有代码都是正确的,但是当我单击登录按钮时,没有任何反应。请帮忙,如果您需要任何其他信息,请询问。
代码:
private void btnLogin_Click(object sender, EventArgs e)
{
int numerror = 0;
if (UsernameTextBox.Text == "")
{
numerror = numerror + 1;
}
if (PasswordTextBox.Text == "")
{
numerror = numerror + 1;
}
if (numerror == 1)
{
ErrorLabel.Text = "*1 required field is blank.";
}
else if (numerror == 2)
{
ErrorLabel.Text = "*2 required fields are blank";
}
else
{
string connectionString = "datasource=localhost;port=3306;username=*****;password=**********";
string select = "SELECT username, password FROM userinfo.users " +
"WHERE username = @username AND password = @password";
using (MySqlConnection Conn = new MySqlConnection(connectionString))
{
using (MySqlCommand cmd = new MySqlCommand(select, Conn))
{
cmd.Parameters.AddWithValue("@username", UsernameTextBox.Text);
cmd.Parameters.AddWithValue("@password", PasswordTextBox.Text);
Conn.Open();
using (MySqlDataReader reader = cmd.ExecuteReader())
{
if (reader.Read())
{
string username = reader.GetString(0);
string password = reader.GetString(1);
if (username == UsernameTextBox.Text)
{
string encodeduserinputpassword = EncodePassword(PasswordTextBox.Text);
if (password == encodeduserinputpassword)
{
AirSpace airspaceform = new AirSpace();
airspaceform.Show();
this.Hide();
}
else
{
CMessageBox("Login Error", "Incorrect username or password.");
}
}
else
{
CMessageBox("Login Error", "Incorrect username or password.");
}
}
}
Conn.Close();
}
}
}
}
最佳答案
您正在通过 EncodePassword
使用编码密码,但您的选择查询正在执行直接匹配。
将您的选择更改为
SELECT username, password FROM userinfo.users
WHERE username = @username
并删除密码参数。
private void btnLogin_Click(object sender, EventArgs e)
{
int numerror = 0;
if (UsernameTextBox.Text == "")
{
ErrorLabel.Text = "*1 required field is blank.";
}
else if (PasswordTextBox.Text == "")
{
ErrorLabel.Text = "*2 required fields are blank";
}
else
{
string connectionString = "datasource=localhost;port=3306;username=*****;password=**********";
string select = "SELECT username, password FROM userinfo.users " +
"WHERE username = @username";
using (MySqlConnection Conn = new MySqlConnection(connectionString))
{
using (MySqlCommand cmd = new MySqlCommand(select, Conn))
{
cmd.Parameters.AddWithValue("@username", UsernameTextBox.Text);
Conn.Open();
using (MySqlDataReader reader = cmd.ExecuteReader())
{
if (reader.Read())
{
string username = reader.GetString(0);
string password = reader.GetString(1);
string encodeduserinputpassword = EncodePassword(PasswordTextBox.Text);
if (password == encodeduserinputpassword)
{
AirSpace airspaceform = new AirSpace();
airspaceform.Show();
this.Hide();
}
else
{
CMessageBox("Login Error", "Incorrect username or password.");
}
}
else
{
CMessageBox("Login Error", "Incorrect username or password.");
}
}
Conn.Close();
}
}
}
}
关于c# - 将用户输入的用户名/密码与 mysql 数据库用户名/密码进行比较不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20501753/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!