如何删除cookie?

时间:2010-01-27 03:27:54

标签: javascript cookies

我创建Cookie的功能是否正确?如何在程序开头删除cookie?有简单的编码吗?

function createCookie(name,value,days)
function setCookie(c_name,value,1) {
  document.cookie = c_name + "=" +escape(value);
}

setCookie('cookie_name',mac);

function eraseCookie(c_name) {
  createCookie(cookie_name,"",-1);
}

9 个答案:

答案 0 :(得分:298)

试试这个:

function delete_cookie( name, path, domain ) {
  if( get_cookie( name ) ) {
    document.cookie = name + "=" +
      ((path) ? ";path="+path:"")+
      ((domain)?";domain="+domain:"") +
      ";expires=Thu, 01 Jan 1970 00:00:01 GMT";
  }
}

或者:

function delete_cookie( name ) {
  document.cookie = name + '=; expires=Thu, 01 Jan 1970 00:00:01 GMT;';
}

答案 1 :(得分:96)

这是Quirksmode上的一个很好的链接。

function setCookie(name,value,days) {
    var expires = "";
    if (days) {
        var date = new Date();
        date.setTime(date.getTime() + (days*24*60*60*1000));
        expires = "; expires=" + date.toUTCString();
    }
    document.cookie = name + "=" + (value || "")  + expires + "; path=/";
}
function getCookie(name) {
    var nameEQ = name + "=";
    var ca = document.cookie.split(';');
    for(var i=0;i < ca.length;i++) {
        var c = ca[i];
        while (c.charAt(0)==' ') c = c.substring(1,c.length);
        if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
    }
    return null;
}
function eraseCookie(name) {   
    document.cookie = name+'=; Max-Age=-99999999;';  
}

答案 2 :(得分:26)

这会有用吗?

function eraseCookie(name) {
    document.cookie = name + '=; Max-Age=0'
}

我知道Max-Age会导致cookie在创建cookie时成为IE中的会话cookie。删除cookie时不确定它是如何工作的。

答案 3 :(得分:15)

您可以通过将到期日期设置为昨天来完成此操作。

将其设置为“-1”不起作用。这标志着一个cookie作为Sessioncookie。

答案 4 :(得分:13)

这是一个delete cookie函数的实现,具有Mozilla的unicode支持:

function removeItem(sKey, sPath, sDomain) {
    document.cookie = encodeURIComponent(sKey) + 
                  "=; expires=Thu, 01 Jan 1970 00:00:00 GMT" + 
                  (sDomain ? "; domain=" + sDomain : "") + 
                  (sPath ? "; path=" + sPath : "");
}

removeItem("cookieName");

如果您使用AngularJs,请尝试$cookies.remove(在其下方使用类似的approach):

$cookies.remove('cookieName');

答案 5 :(得分:9)

要删除cookie,我会再次使用空值设置它,并在1秒后到期。 在细节上,我总是使用以下一种口味(我倾向于选择第二种口味):

<强> 1

    function setCookie(key, value, expireDays, expireHours, expireMinutes, expireSeconds) {
        var expireDate = new Date();
        if (expireDays) {
            expireDate.setDate(expireDate.getDate() + expireDays);
        }
        if (expireHours) {
            expireDate.setHours(expireDate.getHours() + expireHours);
        }
        if (expireMinutes) {
            expireDate.setMinutes(expireDate.getMinutes() + expireMinutes);
        }
        if (expireSeconds) {
            expireDate.setSeconds(expireDate.getSeconds() + expireSeconds);
        }
        document.cookie = key +"="+ escape(value) +
            ";domain="+ window.location.hostname +
            ";path=/"+
            ";expires="+expireDate.toUTCString();
    }

    function deleteCookie(name) {
        setCookie(name, "", null , null , null, 1);
    }

用法:

setCookie("reminder", "buyCoffee", null, null, 20);
deleteCookie("reminder");

<强> 2

    function setCookie(params) {
        var name            = params.name,
            value           = params.value,
            expireDays      = params.days,
            expireHours     = params.hours,
            expireMinutes   = params.minutes,
            expireSeconds   = params.seconds;

        var expireDate = new Date();
        if (expireDays) {
            expireDate.setDate(expireDate.getDate() + expireDays);
        }
        if (expireHours) {
            expireDate.setHours(expireDate.getHours() + expireHours);
        }
        if (expireMinutes) {
            expireDate.setMinutes(expireDate.getMinutes() + expireMinutes);
        }
        if (expireSeconds) {
            expireDate.setSeconds(expireDate.getSeconds() + expireSeconds);
        }

        document.cookie = name +"="+ escape(value) +
            ";domain="+ window.location.hostname +
            ";path=/"+
            ";expires="+expireDate.toUTCString();
    }

    function deleteCookie(name) {
        setCookie({name: name, value: "", seconds: 1});
    }

用法:

setCookie({name: "reminder", value: "buyCoffee", minutes: 20});
deleteCookie("reminder");

答案 6 :(得分:4)

我在删除通过JavaScript制作的Cookie时遇到了问题,并且在我添加了它工作的主机后(向右滚动代码以查看location.host)。清除域上的cookie后,请尝试以下操作以查看结果:

if (document.cookie.length==0)
{
 document.cookie = 'name=example; expires='+new Date((new Date()).valueOf()+1000*60*60*24*15)+'; path=/; domain='+location.host;

 if (document.cookie.length==0) {alert('Cookies disabled');}
 else
 {
  document.cookie = 'name=example; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/; domain='+location.host;

  if (document.cookie.length==0) {alert('Created AND deleted cookie successfully.');}
  else {alert('document.cookies.length = '+document.cookies.length);}
 }
}

答案 7 :(得分:1)

如果您手动创建cookie,则某些其他解决方案可能无法正常工作。

这是删除Cookie的快速方法:

document.cookie = 'COOKIE_NAME=; Max-Age=0; path=/; domain=' + location.host;

答案 8 :(得分:0)

对于只想用 1 行代码删除 cookie 的人:

如果您创建了 cookie,例如在带有 document.cookie = "test=hello"

的网络浏览器控制台中

您可以删除它:

document.cookie = "test=;expires=" + new Date(0).toUTCString()

或者,如果您更喜欢直接写出 UTC 日期:

document.cookie = "test=;expires=Thu, 01 Jan 1970 00:00:00 GMT"

如果您在与 cookie 不同的路径上(例如,如果您想删除在所有路径上使用的 cookie),您可以在 path=/; 之后添加 test=;,如果您在不同的域(例如,当使用 .example.com 而不是 www.example.com 为所有子域设置 cookie 时),您可以在 domain=.example.com; 之后添加 test=;

更新:代替 expires=...,在其他答案中使用 Max-Age=0 也有效(使用 Firefox 测试)。