Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to check if cookies are enabled or disabled in asp.net?

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        if (Request.Browser.Cookies)
        {
            if (Request.QueryString["check"] == null)
            {
                HttpCookie cookie = new HttpCookie("testcookie");
                Response.Cookies.Add(cookie);
                Response.Redirect("Default.aspx?check=1");
            }
            else
            {
                HttpCookie cookie = Request.Cookies["testcookie"];
                if(cookie==null)
                {
                    Label1.Text = "enable cookies";
                }
            }
        }
        else
        {
            Label1.Text = "cookies not supported:";
        }
    }
}

protected void Button1_Click(object sender, EventArgs e)
{
    HttpCookie cookie = new HttpCookie("userinfo");
    cookie["name"] = TextBox1.Text;
    cookie["email"] = TextBox2.Text;
    //cookie.Expires = DateTime.Now.AddDays(30);
    Response.Cookies.Add(cookie);
    Response.Redirect("Default2.aspx");

}

It's not working correctly.

like image 324
Kasirajan Avatar asked May 29 '14 11:05

Kasirajan


1 Answers

See the following link.

http://forums.asp.net/t/1044823.aspx?How+to+check+cookies+enabled+in+a+web+browser+

The only way to check is set a cookie then redirect it and again check if you are able to access it or not. So try below method mentioned in above link.

protected void Page_Load(object sender, EventArgs e)
{
    if (this.IsCookieDisabled())
      errorMsgLabel.Text = Resources.Resource.BrowserDontSupportCookies;

}


private bool IsCookieDisabled()
{
 string currentUrl = Request.RawUrl;

 if (Request.QueryString["cookieCheck"] == null)
 {
     try
     {
            HttpCookie c = new HttpCookie("SupportCookies", "true");
            Response.Cookies.Add(c);

            if (currentUrl.IndexOf("?") > 0)
                currentUrl = currentUrl + "&cookieCheck=true";
            else
                currentUrl = currentUrl + "?cookieCheck=true";

            Response.Redirect(currentUrl);
       }
       catch(Exception ex)
       {
          return false;
       }
 }

 if (!Request.Browser.Cookies || Request.Cookies["SupportCookies"] == null)
      return true;

return false;
}
like image 81
Jalpesh Vadgama Avatar answered Nov 08 '22 17:11

Jalpesh Vadgama