Як видалити файл cookie?


338

Чи правильна моя функція створення файлу 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);
}

1
w3schools має гарні функції для cookie на w3schools.com/js/js_cookies.asp . Ви можете використовувати setCookie('name', 'value', 0)для видалення файлу cookie.
Піт

Відповіді:


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 + '=');
    });
}

2
як мені встановити функцію та перевірити, що таке моє cookie та чи закінчується термін його дії?
kennedy

61
get_cookie не визначено
Kreker

9
Друга версія функції більше не працює Див. Jsfiddle jsfiddle.net/b27Lgxgf/1 . Підхід в anwser @Luca «s працює
Тасос K.

6
Як це має працювати? У JavaScript немає вбудованої get_cookie()функції.
Michał Perłakowski

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

4
Примітка: якщо не працює, переконайтеся, що pathце правильно. дивіться: developers.google.com/web/tools/chrome-devtools/manage-data/…
Gayan Weerakutti

домен слід додати.
Майкл Капустей

3
Також варто зазначити, що і шлях, і домен повинні мати правильні значення.
Есько

Випробувано, працює чудово навіть у WKWebView перед завантаженням сторінки. Гарна робота над рішенням.
ПашаN

32

це працювало б?

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

Я знаю, що Max-Ageпри створенні файлу cookie це cookie сеансу в IE при створенні файлу cookie. Не впевнені, як це працює при видаленні файлів cookie.


17

Ось реалізація функції видалення файлів cookie з підтримкою Unicode від 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 на іншій сторінці та спробувати видалити його з іншої сторінки. набір працює, але не може його видалити.
chovy

2
Я в кінцевому підсумку скористався цим: github.com/carhartl/jquery-cookie І вам доведеться видалити, використовуючи шлях: '/'
chovy

Це хороший підхід, за винятком ... просто встановіть термін придатності до нуля. Це призведе до миттєвого закінчення терміну дії і нікого не бентежить ("Чому розробник встановив термін придатності на вчорашній день? Це була помилка, вони хотіли одноденного строку життя?"). Напишіть код так, щоб він мав більше сенсу, і ваше життя буде менш заплутаним вниз по лінії. Це недооцінена філософія кодування в наші дні ... Навіть MDN пропонує встановити термін придатності до нуля для видалення файлу cookie.
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 вручну.

Ось швидкий спосіб видалити cookie:

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

6

У мене виникли проблеми з видаленням файлу cookie, створеного через JavaScript, і після того, як я додав хост, він працював (прокрутіть код нижче праворуч, щоб побачити цей файл 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);}
 }
}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.