GetInfo.Ru – Компьютерная библиотека
Последние поступления
Как выбрать систему управления базы данных
Базы данных03/09/14
Этапы загрузки UNIX (в схеме)
Unix27/03/12
Gatewall Antispam: тотальный контроль электронной почты
Спам21/04/11
Мастер-класс: создаем Интернет-магазин (Часть 1)
Обзоры ПО20/04/11
CorelDRAW Graphics Suite X5: Что нового?
Обзоры ПО20/07/10
Добавить статью
Самые читаемые материалы
Cookie - это просто(12049)
Что такое cookie и с чем его едят(9300)
Формат и синтаксис Cookie(8128)
Всего статей: 793Всего авторов: 364Подразделов: 47Добавлено за сутки: 0
Статьи  СТАТЬИ Форум  ФОРУМ Рейтинг  РЕЙТИНГ Поиск  ПОИСК Контакты  КОНТАКТЫ
» Главная » Cookies » Cookie - это просто

Cookie - это просто


Xpert
pcxpert@mail.ru
http://pcxpert.net.ru/

Наверное, вы уже успели заметить, что на сайте установлена система отправки сообщений об ошибках Orfo. Я сначала долго размышлял о том, каким образом известить пользователя о наличии системы на странице. Первая мысль - разместить информацию на главной странице. В общем-то метод показался неплохим, но что если пользователь попадет на сайт в обход главной страницы, скажем, из поиска? В конце-концов, изучив проблему, я пришел к выводу, что без cookie и программирования мне не обойтись:

Cookie - что это такое? Это небольшие блоки текстовой информации, которые Web-сервер посылает браузеру, а браузер возвращает неизмененными, когда позже посещает тот же самый Web-сайт или домен. Позволяя серверу читать информацию, которую он послал клиенту раньше, сайт может предоставлять посетителям некоторые услуги, например, представлять сайт в том виде, в котором посетитель его ранее настроил, или разрешать идентифицированным посетителям вход на сайт без ввода пароля. Это не вирус, они не могут ничего прочитать с жесткого диска и не могут переслать данные.

Рассмотрим алгоритм решения задачи.

если (посетитель впервые на сайте или прошло две недели с момента последнего посещения)
    отобразить сообщение

Вот так я представил для себя эту проблему. Обратите внимание - пункты в "если" объединены. Связано это с тем, что в любой из данных ситуации cookie на компьютере пользователя не будет. Почему, можно понять при изучении спецификации - дело в том, что при создании cookie необходимо задать такой параметр, как срок актуальности, после которого cookie будет уже недействителен.

Итак, задача сводится к таким действиям:

проверить наличие cookie
если не существует
    вывести сообщение
    создать, установив срок актуальности две недели

Подробнее о том, как можно проверить наличие cookie. Поскольку как таковой функции проверки в Java Script, а я собирался использовать именно его, нет, то выход из ситуации таков - попытаться его прочитать. Если возникнет ошибка - значит его нет.

Итак:

<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));
}

// -->
</SCRIPT>

Теперь у нас есть функции для работы с cookie. Работаем:

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

// создать экземпляр объекта Date
var now = new Date();
// cookie актуален 14 дней
// 24 часа в дне
// 60 минут в часе
// 60 секунд в минуте
// 1000 миллисекунд в секунде
now.setTime(now.getTime() + 14 * 24 * 60 * 60 * 1000);
// переменная visits взята просто для примера в данном случае можно
// использовать переменную с любым другим именем
var visits = getCookie("was_visited");
// если cookie не найдено, это первый визит
if (!visits) {
    visits = 1; // значение для нового cookie
    alert("Привет, новичок!");
// сохранить новое значение cookie
setCookie("was_visited", visits, now);

// -->
</SCRIPT>

Вот так проблема была мной решена, единственное, что я сделал еще - оформил нахождение cookie отдельной процедурой и затем выделил необходимый скрипт в отдельный файл, оставив в коде страницы только вызов проверяющей функции.

Немного о реальном применении cookies. Яркий пример - сайт GameDev.ru. Здесь мы можем установить понравившийся нам стиль отображения информации, и когда мы придем на сайт в следующий раз, мы его в этом стиле и увидим.

И еще чуть-чуть об удалении:

Возможности удалить cookie вообще-то не имеется, но: Мы можем удалить их косвенно, устанавливая дату истечения срока в прошлом.

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

// * путь и домен по умолчанию присвоены в null и не требуется
// присваивать этого значения, т.к. cookie может быть прочитан
// только тем доменом, который его создал

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";
     }
}

// -->
</SCRIPT>

Вот и все. Как вы видите, в cookie и работе с ними нет ничего сложного. Между тем, это довольно мощное средство хранения информации, которое может использоваться независимо от поддержки сервером каких-либо определенных технологий. Вот почему их применение становится уже почти повсеместным.

P.S. Кстати, применив вот такую инструкцию, мы можем создать персональный счетчик посещений страницы

...
if (!visits) {
     visits = 1;
     alert("Вы здесь впервые.");
} else {
// увеличить счётчик
     visits = parseInt(visits) + 1;
     alert("Вы здесь " + visits + "-й раз.");
     }
// сохранить новое значение cookie
setCookie("was_visited", visits, now);
...

P.P.S. А вот и примеры к статье (3 кб).

Вот теперь уж точно все. Если у вас и после изучения примеров остались какие-то вопросы или недопонимания относительно данной статьи - присылайте их на мой e-mail, я вам с удовольствием отвечу.

 
30.01.2004
Версия для печати Версия для печати Запомнить ссылку Запомнить ссылку
Ваша оценка:  1   2   3   4   5     

 О проектеПерепечаткаАвторамПартнерыО нас пишут
Наверх
©2003—2007. GETINFO.RU. ВСЕ ПРАВА ЗАЩИЩЕНЫ.