Мне интересно, как выйти из сеанса на C# с помощью ASP.NET. Я использую SQL Server для retrive имена пользователей для того, когда они вошли в систему, (2-й блок кода ниже) Непосредственно ниже вот мой код позади моей кнопки входа в систему с моей страницы ASPXКак выйти из системы (с сеансом)
protected void btnLogin_Click(object sender, EventArgs e)
{
string email = txtEmail.Text;
string password = txtPassword.Text;//AQUIRE EMAIL AND PASSWORD AND ADD TO STRINGS
SqlDataReader dataread = null;
SQLconn.Open();
SqlCommand chkLogin = new SqlCommand("SELECT * FROM Member WHERE Email='" + email + "' AND Password='" + password + "'", SQLconn);
dataread = chkLogin.ExecuteReader();
SqlCommand nameAdd = new SqlCommand("SELECT Name FROM Member WHERE Email='" + email + "'", SQLconn);
if (dataread.Read())
{
Response.Write("You are logged in");
Session.Add("userID", dataread[0].ToString());
Session.Add("userFName", dataread[1].ToString());
Session.Add("userEmail", dataread[3].ToString());
Response.Redirect("~/Profiles.aspx");
}
else
{
Response.Write("Please try again. Usernames and Passwords do not match.");
}
SQLconn.Close();
}
Когда они вошедшие в систему, они перенаправляются на другую страницу. Вот код позади для этой страницы
if (Session.Count > 0)
{
if (Session.Count > 0)
{
string name = (string)Session["userFName"];
txtGreeting.Visible = true;
txtGreeting.Text = "Welcome " + name + " , you are logged in! ";
}
}
либо использовать try/catch или 'using' при работе с SqlConn, SqlDataReader и т. Д. – ganders
Нельзя откатывать свою собственную систему аутентификации пользователей, если вы не знаете, что делаете. И вы явно не знаете, что делаете. Вы храните пароли в виде открытого текста в базе данных. Пожалуйста, серьезно относитесь к безопасности для вашего пользователя. Пароли должны храниться только в хешированной форме в базе данных, и ваша система проверки должна сравнивать хешированные значения. – mason
Это локальный проект, который я создаю, не будет пользователей для взлома – user1371055