PHP Delphi CSS HTML JavaScript Perl API ASP MySQL XML С++ VBasic WEB разработка *NIX CouchDB Hack Python
Главная Статьи PHP Cookies в PHP
Главная
 Главная  Контакты
 
Программинг
Статьи Книги ЧаВО
 
xBOOKi
Fresh Books Операционки Сети
 
Поиск
-------
 
Counters
Яндекс цитирования
Rambler's Top100
-------
 
CryptDisk.4h
Программа которая позволяет создать виртуальный шифрованный логический диск.

cryptdisk.4hack.com

-------
 
 

Cookies в PHP

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

Как я уже говорил, браузер клиента можно кормить булками (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/

 



Свежее
Резервное копирование rsync-ом
DNS Amplification (DNS усиление)
Алгоритм Шинглов — поиск нечетких дубликатов текста
Metasploit Framework. Обзор
Использование CouchDB
-------



 
Copyright © 2003-2009   Frikazoid.
Rambler's Top100