Создание сессионных cookies в Javascript для HTML-сайта

Пройдите тест, узнайте какой профессии подходите

Я предпочитаю
0%
Работать самостоятельно и не зависеть от других
Работать в команде и рассчитывать на помощь коллег
Организовывать и контролировать процесс работы

Быстрый ответ

Для создания cookies, которые сохраняются лишь во время текущей сессии браузера в JavaScript, следует отказаться от определения срока действия с помощью атрибутов expires и max-age:

JS
Скопировать код
document.cookie = "sessionKey=yourValue; path=/; secure";

Здесь sessionKey это имя cookie, а yourValueданные, которые сохраняются до момента закрытия браузера. Атрибут secure гарантирует передачу cookie исключительно через HTTPS.

Для удобства хранения данных сессии на стороне клиента, вместо cookies можно использовать sessionStorage:

JS
Скопировать код
sessionStorage.setItem('sessionData', 'yourSessionValue');

где sessionData является ключом элемента, а yourSessionValue — значением сессии.

Кинга Идем в IT: пошаговый план для смены профессии

Управление сессиями без cookies: выпечка без духовки

Если необходимо контролировать сессии без применения серверных скриптов, а только с использованием HTML, для этого отлично подходит sessionStorage, которое предлагает готовое решение.

Очевидно, что данные sessionStorage привязаны к конкретной вкладке или окну, которые инициировали их. В отличие от cookies, информация из sessionStorage не доступна в других вкладках или окнах.

Многомерные cookies: сохранение структурированных данных

Применение JSON.stringify()

Для сохранения сложных, многомерных данных можно применить метод JSON.stringify(), который преобразует их в строку, которую без труда обработает sessionStorage:

JS
Скопировать код
sessionStorage.setItem('complexData', JSON.stringify({ key: 'value' }));
// Мы как в «Проклятии Эль Курадо»: объект внутри объекта внутри... понимаете, о чём я.
let data = JSON.parse(sessionStorage.getItem('complexData'));

Приготовьтесь окунуться в мир, сложность которого может застать врасплох даже Лео Ди Каприо.

Подробнее об этом расскажет наш спикер на видео
skypro youtube speaker

Работа с cookies посредством функций: подход, ориентированный на переиспользование

Для улучшения читаемости и поддерживаемости вашего кода стоит инкапсулировать работу с document.cookie в функции, позволяющие выполнять стандартные операции — создание, чтение и удаление cookies:

JS
Скопировать код
function setSessionCookie(name, value) {
  document.cookie = `${name}=${value}; path=/; secure`;
}

function getSessionCookie(name) {
  let matches = document.cookie.match(new RegExp(
    "(?:^|; )" + name.replace(/([\.$?*|{}\(\)\[\]\\\/\+^])/g, '\\$1') + "=([^;]*)"
  ));
  return matches ? decodeURIComponent(matches[1]) : undefined;
}

function clearSessionCookie(name) {
  document.cookie = `${name}=; path=/; expires=Thu, 01 Jan 1970 00:00:01 GMT;`;
}

Постоянно используйте эти функции — это ваш надёжный спутник в мире cookies. 🍪

Визуализация

Представьте Банку с печеньем (🍪🏺), которая всегда рядом с вами, когда вы заняты работой, но исчезает, когда вы отдыхаете.

Markdown
Скопировать код
Создание cookies для сессии в JavaScript:
JS
Скопировать код
document.cookie = "name=value; path=/;";
Markdown
Скопировать код
Время работы (🏢): [🍪, 🍪, 🍪]
Время отдыха (🚶): []

Во время работы печенье всегда с вами, но как только вы отправляетесь на перерыв, оно исчезает!

Гарантия безопасности: применение правильных атрибутов для cookies

Путь в безопасность

С помощью атрибута path можно контролировать, по каким URL cookies будут отправлены. Этот способ укрепляет безопасность и улучшает эффективность использования cookies:

JS
Скопировать код
document.cookie = "sessionKey=yourValue; path=/secure; secure";

Это подобно банке для печенья с кодом доступа. Имейте в виду: не все cookies созданы равными, поэтому будьте бдительны!

Защита данных

Когда устанавливаете cookie, не забывайте указать атрибут secure, который гарантирует передачу их по защищённому соединению — HTTPS:

JS
Скопировать код
document.cookie = "sessionKey=yourValue; secure";

Этот атрибут защитит ваши cookies от злоумышленников, поджидающих вас по пути!

Проблемы с cookies: распространенные ошибки и способы их решения

Неверное удаление

Ошибки при удалении cookies часто связаны с тем, что при удалении применяются некорректные path или domain:

JS
Скопировать код
// Неверное удаление может не убрать cookie, если путь не совпадает
document.cookie = "sessionKey=yourValue; path=/; expires=Thu, 01 Jan 1970 00:00:01 GMT;";

// Правильное удаление
document.cookie = "sessionKey=; path=/theCorrectPath; expires=Thu, 01 Jan 1970 00:00:01 GMT;";

Для успешного удаления cookies важно правильно указывать имя cookie и путь.

Ограничения в отдельных вкладках

Открытие новой вкладки или окна инициирует новую сессию с отдельным sessionStorage, который недоступен для других вкладок:

JS
Скопировать код
// SessionStorage в исходной вкладке
sessionStorage.setItem('data', 'originalTab');

// В новой вкладке данные будут недоступны
let newData = sessionStorage.getItem('data'); // вернет null

Каждая вкладка — это запертый от остального мира пространство, куда данные из других вкладок не доберутся.

Полезные материалы

  1. Свойство Document: cookie – Web API | MDN — всё о том, как управлять cookies в JavaScript.
  2. Использование HTTP cookies – HTTP | MDN — полезная информация об атрибутах cookies и их отношении к безопасности.
  3. JavaScript Cookies — учебник по управлению cookies.
  4. Cookies, document.cookie — всесторонний анализ работы с cookies, содержит примеры.
  5. Межсайтовая подделка запроса (CSRF) | Фонд OWASP — о важности CSRF-токенов при работе с сессионными cookies.
  6. Понимание cookies с атрибутом SameSite — о связи атрибута SameSite с безопасностью.
  7. Управление сессиями – OWASP Cheat Sheet Series — информация о безопасном управлении сессиями, важная при работе с сессионными cookies.
Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей
Какой атрибут должен быть установлен для защиты cookies при их передаче?
1 / 5