您不应在 ASP.NET MVC 中使用 DataSet 和 SqlDataAdapter。你应该使用模型来代替。
所以让我尝试重写你的代码。首先定义代表您的实体的模型:
public class User
{
public int Id { get; set; }
public string Email { get; set; }
public string Password { get; set; }
}
你也可以有一个ConnectionStatus
model:
公共类连接状态
{
公共 T 结果 { 得到;放; }
公共字符串消息{获取;放 }
}
然后您的数据层可能包含两种方法(一种用于验证凭据,另一种用于获取用户列表):
public static class Db
{
public static ConnectionStatus<bool> Login(string email, string password, string connectionString)
{
string hasedPassword = FormsAuthentication.HashPasswordForStoringInConfigFile(password, "SHA1");
using (SqlConnection sqlCon = new SqlConnection(connectionString))
using (SqlCommand sqlCom = sqlCon.CreateCommand())
{
sqlConn.Open();
sqlCom.CommandText = "SELECT count(*) FROM tblRegister WHERE userEmail=@email AND userPwd=@pwd";
sqlCom.Parameters.AddWithValue("@email", email);
sqlCom.Parameters.AddWithValue("@pwd", hasedPassword);
var status = new ConnectionStatus<bool>();
status.Result = false;
try
{
int rowsFound = Convert.ToInt32(sqlCom.ExecuteScalar());
if (rowsFound == 1)
{
status.Result = true;
status.Message = "User logged in successfully, " + rowsFound;
}
else
{
status.Message = "Invalid email/password combination.";
}
}
catch (Exception ex)
{
status.Message = ex.Message;
}
return status;
}
}
public static ConnectionStatus<IList<User>> GetUsers()
{
using (SqlConnection sqlCon = new SqlConnection(connectionString))
using (SqlCommand sqlCom = sqlCon.CreateCommand())
{
sqlConn.Open();
sqlCom.CommandText = "SELECT userID, userName FROM tblRegister";
var status = new ConnectionStatus<IList<User>>();
status.Result = new List<User>();
try
{
using (var reader = sqlCom.ExecuteReader())
{
while (reader.Read())
{
var user = new User();
user.Id = reader.GetInt32(reader.GetOrdinal("userID"));
user.Email = reader.GetString(reader.GetOrdinal("userName"));
status.Result.Add(user);
}
}
}
catch (Exception ex)
{
status.Message = ex.Message;
}
return status;
}
}
}
然后定义一个视图模型:
public class LoginViewModel
{
public string Command { get; set; }
public string TxtboxEmail { get; set; }
public string TxtboxPassword { get; set; }
}
您的控制器操作将作为参数:
public ActionResult LoginResult(LoginViewModel model)
{
if (model.Command == "Login")
{
string conStr = "Data Source=HUNAIN-PC;Initial Catalog=registration;User ID=sa;Password=abc123!@#";
var loginStatus = Db.Login(model.TxtboxEmail, model.TxtboxPassword, conStr);
ViewBag.Message = loginStatus.Message;
}
var usersStatus = Db.GetUsers(conStr);
return View(usersStatus.Result);
}
最后在你的强类型视图中:
@model IList<User>
@{
ViewBag.Title = "Login Authentication";
}
<h4>@ViewBag.Message</h4>
<table>
@foreach (var user in Model)
{
<tr>
<td>@user.Id</td>
<td>@user.Email</td>
</tr>
}
</table>