Как убить зомби 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>