私はこれで立ち往生していて、本当に数分で頭を壁にぶつけるつもりです。ユーザーがそこにユーザー名とパスワードを入力し、ログインをクリックすると、すべてのユーザーの詳細を取得する関数が呼び出されます。 firstname surname Email AccountType Examtaken 関数内で「Get; Set;」を設定しようとしています。プロパティなので、ホームページで使用できますが、私には知られていない愚かな理由で機能していません! 以下に、ユーザーがログインをクリックしたときに呼び出されるメソッドを示します。
public class ExamMethods
{
public int UserID { get; set; }
public string FirstName { get; set; }
public string Surname { get; set; }
public string Email { get; set; }
public int AccountType { get; set; }
public bool ExamTaken { get; set; }
private enum Datafield
{
UserID,
FirstName,
Surname,
Email,
AccountType,
ExamTaken,
}
public Hashtable CheckLogin(Hashtable Usercredentials)
{
try
{
SqlConnection Connection = new SQLAccess().CreateConnection();
SqlCommand Command = new SqlCommand("GetUserDetails", Connection);
Command.CommandType = System.Data.CommandType.StoredProcedure;
foreach (DictionaryEntry SpParameter in Usercredentials)
{
Command.Parameters.Add(new SqlParameter(SpParameter.Key.ToString(), SpParameter.Value.ToString()));
}
SqlDataReader da = Command.ExecuteReader();
while (da.Read())
{
Details.Add("UserID", da["UserID"]);
UserID = (da.IsDBNull((int)Datafield.UserID)) ? 0 : da.GetInt32((int)Datafield.UserID);
Details.Add("FirstName", da["FirstName"]);
FirstName = (da.IsDBNull((int)Datafield.FirstName)) ? "" : da.GetString((int)Datafield.FirstName);
Details.Add("Surname", da["Surname"]);
Surname = (da.IsDBNull((int)Datafield.Surname)) ? "" : da.GetString((int)Datafield.Surname);
//Details.Add("AccountType", da["AccountType"]);
//AccountType = (da.IsDBNull((int)Datafield.AccountType)) ? 0 : da.GetInt32((int)Datafield.AccountType);
//Details.Add("ExamTaken", da["ExamTaken"]);
//ExamTaken = (da.IsDBNull((int)Datafield.ExamTaken)) ? false : da.GetBoolean((int)Datafield.ExamTaken);
}
Connection.Close();
da.Close();
return Details;
}
catch
{
Console.WriteLine("Error Checking Login Details");
return Details;
}
}
}
上記の while(da.read) im で値をハッシュテーブルに割り当て、debuggin のときに get set メソッドで値が入っていることがわかります。そして、私は100%、この値はnullまたは空ではありません
次に、コードはログイン ページに戻り、すべてが問題なければ、response.redirect をユーザーが試験を受けることができるホームページにリダイレクトしますが、home.aspx のページ ロードには、必要なラベルがあります。ユーザー名を入力して、ExamMethods クラスの get プロパティを参照しますが、null ですか? これはどのように可能ですか?私は何が欠けていますか?これは、home.aspx ページの背後にあるコードです。
public partial class Home : System.Web.UI.Page
{
Hashtable UpdateUser = new Hashtable();
protected void Page_Load(object sender, EventArgs e)
{
Methods.ExamMethods obj_UserDetails = new Methods.ExamMethods();
if (Request.QueryString["uid"] == null)
{
Response.Redirect("Login.aspx");
}
else
lblUserName.Text = obj_UserDetails.FirstName;
}
get set メソッドが何もないのは、ログイン ページからホームページへの reponse.redirect を使用したためですか?