Как удалить куки?

338

Правильно ли моя функция создания 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);
}
Kennedy
источник
1
У w3schools есть хорошие функции для файлов cookie на w3schools.com/js/js_cookies.asp . Вы можете использовать setCookie('name', 'value', 0)для удаления куки.
Пит

Ответы:

341

Попробуй это:

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;';
}

Вы можете определить get_cookie()так:

function get_cookie(name){
    return document.cookie.split(';').some(c => {
        return c.trim().startsWith(name + '=');
    });
}
ACP
источник
2
Как мне установить функцию и проверить, что такое мои куки и не истек ли срок их действия?
Кеннеди
61
get_cookie не определено
Kreker
9
Вторая версия функции больше не работает. См. Jsfiddle jsfiddle.net/b27Lgxgf/1 . Подход в работах @Luca's anwser
Тасос К.
6
Как это должно работать? JavaScript не имеет встроенной get_cookie()функции.
Михал Перлаковский
4
@ MichałPerłakowski Я почти уверен, что это было предназначено только как заполнитель / ссылка на реальную функцию, которую вы бы определили в другом месте.
JSeligsohn
114

Здесь хорошая ссылка на 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;';  
}
Лука Маттеис
источник
20
примечание: toGMTString устарел в пользуtoUTCString
drzaus
4
примечание: в случае, если не работает, убедитесь, что pathэто правильно. см .: developers.google.com/web/tools/chrome-devtools/manage-data/…
Гаян Виракутти
домен должен быть добавлен.
Михаил Капустей
3
Также стоит отметить, что и путь, и домен должны иметь правильные значения.
Эско
Протестировано, отлично работает даже в WKWebView, до загрузки страницы. Хорошая работа по решению.
PashaN
32

это будет работать?

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

Я знаю, Max-Ageчто при создании cookie файл cookie становится файлом cookie сеанса в IE. Не уверен, как это работает при удалении куки.

Коллин Андерсон
источник
При установке на ноль срок действия файла cookie истекает при закрытии окна браузера.
AyexeM
17

Вот реализация функции удаления cookie с поддержкой юникода от Mozilla:

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 (под ним используется аналогичный подход ):

$cookies.remove('cookieName');
Виталий Федоренко
источник
17

Вы можете сделать это, установив дату истечения срока на вчера.

Установка его в «-1» не работает. Это отмечает печенье как Sessioncookie.

Маркус Нордхаус
источник
Ваш пример не работает, если вы установили cookie на другой странице и попытаетесь удалить его с другой страницы. набор работает, но не может удалить его.
Чови
2
Я закончил тем, что использовал это: github.com/carhartl/jquery-cookie И вы должны удалить, используя путь: '/'
chovy
Это хороший подход, кроме ... просто установите время истечения нуля. Это приведет к мгновенному истечению и никого не смущает («Почему разработчик установил время истечения вчерашнего дня? Было ли это ошибкой, они хотели, чтобы продолжительность жизни составляла один день?»). Напишите код, чтобы он имел больше смысла, и ваша жизнь будет менее запутанной. В наши дни это недооцененная философия в кодировании ... Даже MDN предлагает установить время истечения нуля, чтобы удалить куки.
dudewad
10

Чтобы удалить 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");
Люка Боррионе
источник
8

Некоторые из других решений могут не работать, если вы создали cookie вручную.

Вот быстрый способ удалить куки:

document.cookie = 'COOKIE_NAME=; Max-Age=0; path=/; domain=' + location.host;
Lemmings19
источник
6

У меня были проблемы с удалением куки, созданного с помощью JavaScript, и после добавления хоста он работал (прокрутите код ниже, чтобы увидеть его location.host). После очистки куки в домене попробуйте следующее, чтобы увидеть результаты:

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);}
 }
}
Джон
источник