删除具有相同名称但路径不同的cookie

JKo*_*own 12 javascript cookies path client-side

我需要删除具有相同名称但路径不同的客户端cookie.在javascript中执行此操作的最佳方法是什么?

Jon*_*ski 18

只需指定要删除的Cookie的相同路径,即可将其过期.

document.cookie = 'name=value1; path=/';
document.cookie = 'name=value2; path=/path/';

alert(document.cookie); // name=value1; name=value2


document.cookie = 'name=; path=/path/; expires=' + new Date(0).toUTCString();

alert(document.cookie); // name=value1
Run Code Online (Sandbox Code Playgroud)

将其更改为使用路径的cookie过期/仍然只会使其中一个cookie失效 - 给定的路径必须与路径集匹配:

document.cookie = 'name=; path=/; expires=' + new Date(0).toUTCString();

alert(document.cookie); // name=value2
Run Code Online (Sandbox Code Playgroud)

要删除这两个,您必须使用它们的路径到期:

document.cookie = 'name=; path=/; expires=' + new Date(0).toUTCString();
document.cookie = 'name=; path=/path/; expires=' + new Date(0).toUTCString();

alert(document.cookie); // {blank}
Run Code Online (Sandbox Code Playgroud)

现在,这些示例假设您正在浏览它/path/或它的子目录.


[编辑]

要批量删除,请尝试以下方法:

function expireAllCookies(name, paths) {
    var expires = new Date(0).toUTCString();

    // expire null-path cookies as well
    document.cookie = name + '=; expires=' + expires;

    for (var i = 0, l = paths.length; i < l; i++) {
        document.cookie = name + '=; path=' + paths[i] + '; expires=' + expires;
    }
}

expireAllCookies('name', ['/', '/path/']);
Run Code Online (Sandbox Code Playgroud)

演示:http://jsfiddle.net/M2dZ3/

您还可以通过拆分和迭代伪造路径查找window.location.pathname:

function expireActiveCookies(name) {
    var pathname = location.pathname.replace(/\/$/, ''),
        segments = pathname.split('/'),
        paths = [];

    for (var i = 0, l = segments.length, path; i < l; i++) {
        path = segments.slice(0, i + 1).join('/');

        paths.push(path);       // as file
        paths.push(path + '/'); // as directory
    }

    expireAllCookies(name, paths);
}
Run Code Online (Sandbox Code Playgroud)

演示:http://jsfiddle.net/M2dZ3/2/