0

我坚持这一点,我真的要在几分钟内把我的头撞到墙上我有一个日志页面,用户在其中输入用户名和密码,并在他们按下此按钮时单击登录,调用一个函数来获取所有用户详细信息,即firstname surname Email AccountType Examtaken 等函数中我试图设置“获取;设置;” 属性,所以我可以在主页上使用它们,但由于某些愚蠢的原因,我不知道它不起作用!下面你会看到当用户点击登录时调用的方法

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) 中看到的那样,我在调试时将值分配给哈希表和 get set 方法,我可以看到值进入!我 100% 这个值不是 null 或空的

然后代码返回登录页面,如果一切正常,则返回登录页面,然后 response.redirect 到用户可以参加考试的主页,但是在 home.aspx 的页面加载中,我有一个我想要的标签popualte 与用户名,所以我引用了 ExamMethods 类的 get 属性,但它为空?这怎么可能?我错过了什么?这是后面 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;

       }

是不是因为我从登录页面到主页使用了reponse.redirect,所以get set方法什么都不是?

4

3 回答 3

7

处理网页时,变量不会在网页之间共享。您可能知道 HTTP 是一种无状态协议。

那么我该怎么做呢?

你需要状态管理。你需要一种方法来传递信息。据我所知,Sessions似乎是存储您需要在多个页面中使用的这些数据的最佳位置。

但是会话并不是您拥有的唯一状态管理选项。您还有更多内容,具体取决于您要存储的内容、要存储的数量以及要在何处/何时访问它们。

我建议您阅读有关ASP .NET 状态管理的内容,也阅读有关建议以了解在哪种情况下使用哪种状态管理功能。

于 2012-04-21T17:43:58.243 回答
3

Page_Load方法中,您Methods.ExamMethods()每次都创建一个新实例,因此它的所有属性都没有被初始化。重定向到登录页面后,执行登录并被重定向回来,Page_Load再次执行并创建该类的新实例。

首选的方法是根据uid您在QueryString.

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
    {
        if (!Page.IsPostback)
        {
            //read value of uid parameter
            int uid = Request.QueryString["uid"];
            //access database to retrieve user's details
            obj_UserDetails = GetUserDetails(uid);
            lblUserName.Text = obj_UserDetails.FirstName;
        }
    }

}

值得一提的是,您可以使用Page.IsPostback属性来填充用户数据的控件。回发ViewState机制应保留控件的内容。

还有一些其他机制允许您在页面之间传递数据,例如Session state。如果您需要更多页面上的用户详细信息而不仅仅是这两个页面,则可以使用此选项。这样您就不必经常访问数据库。

使用Server.Transer()方法将用户重定向到另一个页面并使用PreviousPage对象也可以让您访问其他页面,但我认为直接在主页QueryString上使用和读取数据在您的情况下是最合适的。

可能有用的链接:

于 2012-04-21T17:47:13.043 回答
1

当您浏览 Web 上的页面时,实例不会保持活动状态,您可以在会话中存储您需要的内容并在新页面加载时获取它您可以在需要存储数据时执行此操作

Session["data"] = new Data("SomeData");

当您再次需要数据时,您可以执行此操作

var data = Session["data"] as Data;
if(data != null)
//do something with the data
于 2012-04-21T17:56:10.190 回答