0

我有一个在用户登录应用程序时创建 cookie 的应用程序。然后,后续页面会读取 cookie,如果用户已登录(cookie 存在),则允许用户继续在这些页面上进行处理。当我在 IE 8.0 上运行我的应用程序时,cookie 会按预期响应。当我通过 VS2008 运行我的应用程序时,cookie 会按我的预期响应。当我在 Firefox 4.0 中运行我的应用程序时,cookie 在我的下一页上无效。

这是我的 cookie 的代码设置

protected void btnLogin_Click(object sender, EventArgs e)
{
    if (CheckFields())
    {
        string strSQL;
        sqlUserInfo.SelectParameters.Clear();
        strSQL = "SELECT FirstName, LastName, Email FROM UserInfo WHERE Email=@email AND Password=@password";
        sqlUserInfo.SelectCommand = strSQL;
        if (txtEmail.Text != "")
        {
            sqlUserInfo.SelectParameters.Add("email", txtEmail.Text);
            sqlUserInfo.SelectParameters.Add("password", txtPassword.Text);
            DataView dv = (DataView)sqlUserInfo.Select(DataSourceSelectArguments.Empty);
            if (dv.Table.Rows.Count > 0)
            {
                string welcomeMsg = "Welcome back " + dv[0][0] + " " + dv[0][1] + "!";
                HttpCookie cookie = new HttpCookie("Email");
                cookie.Value = txtEmail.Text;

                DateTime dtNow = DateTime.Now;
                Response.Cookies.Add(cookie);

                lblMenu.Text = welcomeMsg + "&nbsp;&nbsp;&nbsp; <a href='AcctInfo.aspx'>Update Account Info</a>&nbsp;&nbsp;&nbsp;<a href='TextAlerts.aspx'>Create/Update Text Alerts</a>&nbsp;&nbsp;&nbsp;<a href='graphSetup.aspx'>Graphing</a>";
                lblMessage.Text = "";
                btnLogin.Enabled = false;
                btnLogoff.Enabled = true;
            }
            else
            {
                lblMessage.Text = "Login Unsuccessful";
            }
        }
    }
}

这是我加载下一页的代码,即 acctinfo.aspx.cs

 protected void Page_Load(object sender, EventArgs e)
    {
        cookie = Request.Cookies["Email"];
        if (cookie == null)
        {
            lblMessage.Text = "Not logged in. <a href='login.aspx'>Login</a>";
            lbLogoff.Visible = false;
        }
        else
        {
            EnableControls();
            string strSQL;

            sqlUserInfo.SelectParameters.Clear();
            strSQL = "SELECT FirstName, LastName, Email, Password, PhoneNumber, Provider FROM UserInfo WHERE Email=@email";
            sqlUserInfo.SelectCommand = strSQL;
            sqlUserInfo.SelectParameters.Add("email", cookie.Value.ToString());
            DataView dv = (DataView)sqlUserInfo.Select(DataSourceSelectArguments.Empty);
            if (dv.Table.Rows.Count > 0)
            {
                oldPass = dv[0][3].ToString();
                oldPhone = dv[0][4].ToString();
                oldProvider = dv[0][5].ToString();
                if (!IsPostBack)
                {
                    txtPassword.Text = oldPass;
                    txtPassword2.Text = oldPass;
                    txtPhone.Text = oldPhone;
                    lstProvider.SelectedValue = oldProvider;
                    strMenu = "Welcome " + dv[0][0].ToString() + " " + dv[0][1].ToString() + "&nbsp;&nbsp;&nbsp;<a href='TextAlerts.aspx'>Create/Update Text Alerts</a>&nbsp;&nbsp;&nbsp;<a href='graphSetup.aspx'>Graphing</a>&nbsp;&nbsp;&nbsp;";
                    lblMenu.Text = strMenu;
                }
            }
        }
    }

在 Firefox 中启用了 Cookie,因为我可以从它所在的文件中删除保存 cookie 的代码,将其放入一个单独的文件中,浏览该文件,然后浏览我的 AcctInfo,它可以按预期工作。

任何帮助将不胜感激。

谢谢!

4

2 回答 2

1

使用 Fiddler 或其他 Http watcher 工具查看实际发送到浏览器/从浏览器发送的内容。代码本身看起来不错。

于 2011-05-02T22:07:32.830 回答
0

看起来您的 cookie 已设置为立即过期,请尝试以下代码

HttpCookie cookie = new HttpCookie("Email"); 
        cookie.Value = txtEmail.Text;

        DateTime dtNow = DateTime.Now;
        cookie.Expires = DateTime.Now.AddYears(1);
        Response.Cookies.Add(cookie);
于 2011-05-02T21:58:11.943 回答