Отправляет email-рассылки с помощью сервиса Sendsay

Твой первый сайт

  Все выпуски  

Твой первый сайт: от А до Я



Рассылки сайта "Время России" на subscribe.ru


Твой первый сайт: от А до Я


Колонка редактора

ВНИМАНИЕ!!! Стартовал проект: "Путь к стройности"

5 неожиданных путей к плоскому животу

50 СПОСОБОВ ПОХУДЕТЬ БЕЗ ДИЕТ

Есть или не есть после шести вечера?

Как снизить аппетит

7 способов быстро сбросить вес

Правильная осанка – самый быстрый способ стать стройнее

Как похудеть, не испытывая чувства голода?


  Хиты продаж

Cookies в PHP


Лучшие рассылки на
Subscribe.ru


Компьютерная литература -
105  электронных учебников умещающихся на 3 CD

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

Энциклопедия вебмастера - Супер сборник на двух CD, который будет просто необходим, как начинающим сайтостроите-лям так и продвинутым вебмастерам.

Энциклопедия манипулирова-ния или как самостоятельно изучить НЛП и гипноз (2 CD)

Энциклопедия начинающего крэкера

 Учебный сборник на CD  "Уроки Вебмастерства"

    Михаил Соловьев

   Как я уже говорил, браузер клиента можно кормить булками (cookies). Рассказав общее устройство cookies, расскажу о том, как это реализуется на конкретном примере, а именно в языке PHP. Рассказ о cookies в perl, возможно, давал бы больше информации о технической стороне установки cookie (в perl заголовки сообщений http надо писать руками), но зато в PHP это удобнее реализовано.

   В PHP одна и та же функция setcookie отвечает за создание, изменение и удаление cookies. Рассмотрим простейший пример - установка на компьютере пользователя булки с информацией о том, был он на этой странице или нет. Это делается так:

   <? setcookie ("visted","true"); ?>

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

   int setcookie ( string name [, string value [, int expire
[, string path [, string domain [, int secure]]]]])

   Как видите, мы можем указать не только имя cookie и значение, но также и время действия (expire - в секундах, прошедших с 1970-го года), путь (стандартное значение "/"), домен ("домен.установившего.куки.скрипта") и секьюрность (0), т.е. также и область действия cookie.

   Существует ограничение по количеству cookie на домен (20 штук), поэтому на самом деле в cookie хранится массив, и мы можем в одной булке хранить имя пользователя и количество его заходов на страницу (просто используйте значение cookie как массив). Рассмотрим скрипт - счетчик посещения страницы пользователем.

   <? if (!empty($HTTP_COOKIE_VARS["count"]))
{
$howmuch = $HTTP_COOKIE_VARS["count"];
} else
{
$howmuch = 0;
};
$howmuch++;
setcookie("count",$howmuch,time() + 3600);

print "Вы на этой странице $howmuch-й раз."; ?>

   Как видите, для начала мы проверяем, есть ли уже на компьютере пользователя cookie с именем "count", и, если его нет, считаем, что пользователь был на странице 0 раз. Доступ к информации из cookie может быть получен двумя способами: во-первых, если в php.ini установлена настройка register_globals, автоматически создается переменная $count, во-вторых, добавляется значение в массив $HTTP_COOKIE_VARS. Более правильным является использование второго способа, т.к. PHP очень любит создавать переменные, и в этом случае мы просто не знаем - породилась ли эта переменная в результате передачи скрипту данных в query_string, через метод POST или через cookie. Кроме того, в последних версиях PHP (4.2) функция register_globals по умолчанию отключена, так что остается вообще только один способ получить информацию.

   Следующим шагом является прибавление к счетчику посещений единички. Логично - пользователь ведь зашел на страницу? Значит, увеличил количество посещений на единичку. Затем ( до выдачи каких-либо надписей ) мы должны установить cookie c новой информацией, действующий час. Чтобы получить время в секундах от 1970-го года, используется функция time(), к которой мы прибавляем искомое время (3600 секунд). Следует отметить, что время устанавливается в часовом поясе пользователя, так что запросто может оказаться, что время жизни cookie уже истекло. С этим надо бороться!

   И только после того, как мы установили cookie мы можем начать что-то показывать пользователю, что мы и делаем, печатая количество посещений им этой страницы.

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

   Но мы должны не только уметь добавить cookie, но и удалить... Это делается все той же многострадальной функцией setcookie , только на этот раз мы вызываем ее с одним единственным параметром - именем cookie:

   <? setcookie("count"); ?>

   Вот и все! Кормите браузер булками!

   Источник: http://webhowto.ru/


"Домашний компьютер: от А до Я"

Анекдоты, которые расмешили всю Россию

"Мышеловка" или всё о мошеничестве в Интернет

Коллекция самых необходимых ссылок по Internet

Рассылка для настоящих мужчин

Интернет без секретов: курс молодого бойца

Ах какая женщина" или как стать счастливой в короткий срок

Худеем в два счёта

Интернет или как стать продвинутым пользователем

Как стать обаятельной и привлекательной

Кулинарное искусство
 

 

ЖДЁМ   ПИСЕМ


В избранное