JavaScript Cookie Functions

В этой части мы покажем некоторые универсальные функции для манипулирования cookies. Для удобства понимания в текст скрипта добавлены комментарии. Для их использования достаточно скопировать их отсюда с помощью функции Copy и вставить внутри пары тегов <HEAD>...</HEAD> в вашей странице HTTP.

<SCRIPT LANGUAGE="JavaScript">
<!--

// name - имя cookie
// value - значение cookie
// [expires] - дата окончания действия cookie (по умолчанию - конец текущей  //  сессии)
// [path] - путь, где cookie верны (по умолчанию - путь к текущему документу)
// [domain] - домен, где cookie верны (по умолчанию - домен вызываемого 
// документа)
// [secure] - бинарная переменная, показывающая, что cookie должны
// передаваться через защищённое соединение
// * по умолчанию аргументу присвоено значение null
// * нулевое значение не требуется присваивать пропущенным переменным
function setCookie(name, value, expires, path, domain, secure) {
  var curCookie = name + "=" + escape(value) +
      ((expires) ? "; expires=" + expires.toGMTString() : "") +
      ((path) ? "; path=" + path : "") +
      ((domain) ? "; domain=" + domain : "") +
      ((secure) ? "; secure" : "");
  document.cookie = curCookie;
}

// name - имя cookie
// * строка возврата содержит значения необходимого cookie или null при
// его отсутствии
function getCookie(name) {
  var dc = document.cookie;
  var prefix = name + "=";
  var begin = dc.indexOf("; " + prefix);
  if (begin == -1) {
    begin = dc.indexOf(prefix);
    if (begin != 0) return null;
  } else
    begin += 2;
  var end = document.cookie.indexOf(";", begin);
  if (end == -1)
    end = dc.length;
  return unescape(dc.substring(begin + prefix.length, end));
}

// name - имя cookie
// [path] - путь, где cookie верны (должен быть тем же, что и путь при
// создании cookie)
// [domain] - домен, где cookie верны (должен быть тем же, что и домен при
// создании cookie
// * путь и домен по умолчанию присвоены в null и не требуется
// присваивать этого значения
function deleteCookie(name, path, domain) {
  if (getCookie(name)) {
    document.cookie = name + "=" + 
    ((path) ? "; path=" + path : "") +
    ((domain) ? "; domain=" + domain : "") +
    "; expires=Thu, 01-Jan-70 00:00:01 GMT";
  }
}

// date - экземпляр объекта Date
// * все экземпляры объекта Date передаются этой функции "для
// ремонта"
function fixDate(date) {
  var base = new Date(0);
  var skew = base.getTime();
  if (skew > 0)
    date.setTime(date.getTime() - skew);
}

// -->
</SCRIPT>

В следующей части показан пример персонального счётчика посетителя страницы, показывающий общее число её посещений именно этим пользователем, который использует яти функции.

To Cat-Webmaster К коту-вебмастеру ...

Copyright © 1997 Mecklermedia Corporation.
All Rights Reserved. Legal Notices.
Created: December 4, 1997
Revised: December 4, 1997
Перевод: Александр Серёгин aka Free Cat 21.07.1999

Оригинальная статья: http://www.webreference.com/js/column8/