Главная · Статьи · Файлы · Фото галерея · Видео онлайн
Библиотека
По авторам
По жанрам
Поиск по названию
Навигация
Главная
Статьи
Файлы
Обратная связь
Фото галерея
Видео онлайн
Поиск

Работа
Заказать сайт или программу

Примеры работ
Последние статьи
Технология уничтожения
«Мы – русские»
Ф.М. Достоевский - Д...
Европа против России...
Первые английские ко...
Reklama

Урок 8. Сессии и cookies.

Сессии и cookies предназначены для хранения сведений о пользователях при
переходах между несколькими страницами. При использовании сессий данные
сохраняются во временных файлах на сервере. Файлы с cookies хранятся на
компьютере пользователя, и по запросу отсылаются броузером серверу.



Использование сессий и cookies очень удобно и оправдано в таких приложениях как
Интернет-магазины, форумы, доски объявлений, когда, во-первых, необходимо
сохранять информацию о пользователях на протяжении нескольких станиц, а,
во-вторых, своевременно предоставлять пользователю новую информацию.



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



При работе с сессиями различают следующие этапы:



открытие сессии

регистрация переменных сессии и их использование

закрытие сессии

Открытие сессии

Самый простой способ открытия сессии заключается в использовании функции
session_start, которая вызывается в начале PHP-сценария:



session_start

Синтаксис:



session_start();



Эта функция проверяет, существует ли идентификатор сессии, и, если нет, то
создает его. Если идентификатор текущей сессии уже существует, то загружаются
зарегистрированные переменные сессии.



Регистрация переменных сессии

Вообще говоря, регистрация переменных сессии осуществляется при помощи функции
session_register:



session_register

Синтаксис:



bool session_register(mixed name [,mixed...]);



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



session_register("username");



К примеру:



<?

$name = "maksim";

$maksim = "my_name";

session_register($name) // регистрируется переменная "maksim" со

// значением "my_name"

?>





если вы используете функцию session_register, то должен быть включен параметр
register_globals в php.ini



Для корректной работы приложения необходимо проверять, установлены ли переменные
сессии. Такую проверку можно сделать при помощи функции session_is_registered:



$result = session_is_registered("username");





Закрытие сессии

После завершения работы с сессией сначала нужно разрегистрировать все переменные
сессии, а затем вызвать функцию session_destroy:



session_destroy

Синтаксис:



session_destroy();



Способы разрегистрации сеансовых переменных различаются в зависимости от того,
каким способом они были зарегистрированы.



При включенном register_globals и использовании функции session_register
разрегистрация осуществляется при помощи функции session_unregister:



session_unregister

Синтаксис:



session_unregister("username");



Если же регистрация осуществлялась путем с применением ассоциативных массивов,
то поступают следующим образом:



unset

Синтаксис:



unset($_SESSION["username"]);



Пример простой сессии

Рассмотрим пример простой сессии, работающей с тремя страницами. При посещении
пользователем первой страницы открывается сессия и регистрируется переменная
$username. Соответствующий код реализации приведен в листинге:



<?

session_start();

$_SESSION['username'] = "maksim";

echo 'Привет, '.$_SESSION['username']."<br>";

?>

<a href="page2.php">На следующую страницу </a>





После этого, пользователь maksim нажимает на ссылку и попадает на страницу
page2.php, код которой приведен в листинге:



<?

session_start();

echo $_SESSION['username'].' , ты пришел на другую страницу этого сайта!';

echo("<br>");

?>

<a href="page3.php">На следующую страницу </a>









При нажатии на ссылку, пользователь попадает на страницу page3.php, при этом
происходит разрегистрация сеансовой переменной и уничтожение сессии.
Соответствующий код реализации приведен в листинге:



<?

session_start();

unset($_SESSION['username']); // разрегистрировали переменную

echo 'Привет, '.$_SESSION['username'];

/* теперь имя пользователя уже не выводится */

session_destroy(); // разрушаем сессию

?>


Комментарии
Нет комментариев.
Добавить комментарий
Пожалуйста залогиньтесь для добавления комментария.
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Забыли пароль?
Запросите новый здесь.
Сейчас на сайте
Гостей: 4
На сайте нет зарегистрированных пользователей

Пользователей: 1
Не активированный пользователь: 0
новичок: AMD
Статистика
Яндекс.Метрика
Rambler's Top100


PR-CY.ru
Protected by Copyscape Online Plagiarism Checker
Back To Top Back To Top Back To Top

Best Viewed 1280x1024