Как убить зомби cookies

Я не уверен, что мой вопрос связан с этот или нет.

IE9 удаляет этот файл cookie после закрытия браузера (ожидается), но Chrome 12, Firefox 5 и Opera 11 этого не делают. (Во время тестирования приведенного ниже примера каждый браузер был закрыт после нажатия кнопки "Удалить учетную запись"."Затем они были снова открыты через короткий промежуток времени, и во всех, кроме IE9, печенье все еще было там.)

Использовать Случае: Cookie истекает через 1 год после последнего посещения пользователь. Удаление учетной записи должно удалить cookie.

вопрос:
(1/2) почему IE9 делает правильную (ожидаемую) вещь, а другие-нет?
(2/2) как я могу гарантировать, что все браузеры уничтожат этот файл cookie?

пример:

логин.HTML-код

<!doctype html>
<html>
    <head>
        <title>Create Cookie Example</title>

        <script>
            function setCookie() {
                var expDate = new Date();
                expDate.setDate(expDate.getDate() + 365);
                document.cookie = "fakeCookie=" + escape("fake value")
                    + "; expires=" + expDate.toGMTString();
            }
        </script>
    </head>

    <body onload="setCookie()">
        <h1>Welcome</h1>
        <p>Lorem ipsum...</p>
        <hr size="1" />
        <p><a href="profile.html">User Profile</a></p>
    </body>
</html>

профиль.HTML-код

<!doctype html>
<html>
    <head>
        <title>Delete Cookie Example</title>

        <script>
            function deleteConfirm() {
                if ( confirm("Are you sure you want to delete your account? "
                           + "All data will be lost; this action cannot be undone!")
                   ) deleteConfirmed()
                else return false

                return true;
            }

            function deleteConfirmed() {
                document.cookie = "fakeCookie=; expires=Thu, 01-Jan-70 00:00:01 GMT";
            }
        </script>
    </head>

    <body>
        <h1>User Profile</h1>
        <p>Lorem ipsum...</p>
        <hr size="1" />
        <p><a href="index.html" onclick="return deleteConfirm()">Delete Account</a></p>
    </body>
</html>

Edit: исходный пост неправильно идентифицированный логин.html как индекс.html (формирование круговая ссылка, которая воссоздаст файл cookie при удалении "учетной записи".)

1 ответов


OP придумал этот ответ и первоначально отредактировал его в вопрос. Это просто репост, чтобы сохранить решение в ответ, для семантики.

        <script>
            function deleteConfirm() {
                if ( confirm("Are you sure you want to delete your account? "
                           + "All data will be lost; this action cannot be undone!")
                   ) deleteConfirmed(); // <-- ** MISSED SEMICOLON HERE **
                else return false;      // <-- ** AND HERE **

                return true;
            }

            function deleteConfirmed() {
                document.cookie = "fakeCookie=; expires=Thu, 01-Jan-70 00:00:01 GMT";
            }
        </script>