Разделы презентаций


Сессии

Содержание

Определение сессииWeb-сессия – специальный ключ (идентификатор сессии), хранящийся клиентской программой и сопоставляемый с пользовательскими данными на стороне сервера.Сессии предназначены для хранения и передачи данных отдельного пользователя между динамическими страницами одного ресурса.

Слайды и текст этой презентации

Слайд 1Сессии
Лекция 6

СессииЛекция 6

Слайд 2Определение сессии
Web-сессия – специальный ключ (идентификатор сессии), хранящийся клиентской программой

и сопоставляемый с пользовательскими данными на стороне сервера.
Сессии предназначены для

хранения и передачи данных отдельного пользователя между динамическими страницами одного ресурса.
Определение сессииWeb-сессия – специальный ключ (идентификатор сессии), хранящийся клиентской программой и сопоставляемый с пользовательскими данными на стороне

Слайд 3Причины появления сессий
Web-сервер каждый раз при обращении к очередной странице

инициализирует новую HTTP-транзакцию без возможности связывания старых данных пользователя с

вызовом новой динамической страницы.
Причины появления сессийWeb-сервер каждый раз при обращении к очередной странице инициализирует новую HTTP-транзакцию без возможности связывания старых

Слайд 4Способы хранения ключа сессии на стороне клиента
Ключ (идентификатор сессии) на

стороне клиента может храниться двумя способами:
В HTTP-Cookie (относительно безопасно)
Как часть

URL (небезопасно)
Способы хранения ключа сессии на стороне клиентаКлюч (идентификатор сессии) на стороне клиента может храниться двумя способами:В HTTP-Cookie

Слайд 5Хранение сессии на стороне сервера
Способы хранения данных внутри сессии никак

не регламентируются и могут быть представлены различными способами: в структурных

файлах сервера, в БД различного типа и т.д.
Данные сессии хранятся на сервере в виде массива.
Хранение сессии на стороне сервераСпособы хранения данных внутри сессии никак не регламентируются и могут быть представлены различными

Слайд 6Использование сессий
Сессии могут использоваться для тех же целей, что и

HTTP Cookie, но с сохранением данных на стороне сервера.
С

помощью сессий также реализуются следующий функционал:
Подтверждение авторизации пользователя на сайте
Хранение временных данных, вводимых из нескольких форм
Корзина в интернет-магазине
Хранение символьного значения картинки из CAPTCHA



Использование сессийСессии могут использоваться для тех же целей, что и HTTP Cookie, но с сохранением данных на

Слайд 7Механизм работы сессий
Ключ считывается с сервера либо из строки URL,

либо из Cookie
На этапе проверки ключа проверяется, существуют ли данные

на сервере, сопоставляемые с этим ключом.
Ключ генерируются таким образом, чтобы исключить возможность его подмены.
Механизм работы сессийКлюч считывается с сервера либо из строки URL, либо из CookieНа этапе проверки ключа проверяется,

Слайд 8Сессии в PHP
Ключ PHP-сессии, сохраняемый в Cookie, именуется по-умолчанию PHPSESSID.
Значения

сессии хранятся в суперглобальном массиве $_SESSION

Сессии в PHPКлюч PHP-сессии, сохраняемый в Cookie, именуется по-умолчанию PHPSESSID.Значения сессии хранятся в суперглобальном массиве $_SESSION

Слайд 9Сохранение данных сессии
session_start(); /* инициализация механизма работы сессии */
$_SESSION["user"] =

"pavel"; /* Сохранение переменной сессии "user" со значением "pavel" */
if(isset($_SESSION["user"])

&& !empty($_SESSION["user"]))
{
print "Пользователь авторизован";
}
else
{
print "Требуется авторизация";
}
Сохранение данных сессииsession_start(); /* инициализация механизма работы сессии */$_SESSION[

Слайд 10Удаление данных сессии
Для того, чтобы удалить переменную сессии, достаточно опустошить

индекс ассоциативного суперглобального массива $_SESSION:
unset($_SESSION["items"]);
// Пользователь удалил все товары

из корзины покупок
Удаление данных сессииДля того, чтобы удалить переменную сессии, достаточно опустошить индекс ассоциативного суперглобального массива $_SESSION:unset($_SESSION[

Слайд 11Удаление всей сессии
Для того, чтобы удалить полностью текущую сессию пользователя,

можно вызвать функцию session_destroy():
session_destroy();
// Пользователь нажал кнопку "Выход", а

значит более он не авторизован

Удаление всей сессииДля того, чтобы удалить полностью текущую сессию пользователя, можно вызвать функцию session_destroy():session_destroy(); // Пользователь нажал

Слайд 12Функции работы с идентификатором и его именем
Функция, возвращающая текущий идентификатор

сессии:
string session_id ([ string $id ] )
Функция, возвращающая или устанавливающая

(если указана переменная $name) имя переменной Cookie для идентификатора сессии:
string session_name ([ string $name ] )
Функции работы с идентификатором и его именемФункция, возвращающая текущий идентификатор сессии:string session_id ([ string $id ] )Функция,

Слайд 13Безопасность сессии
Узнав идентификатор сессии, злоумышленник может получить доступ к учётной

записи другого пользователя. Способы получения идентификатора:
Перехватка GET-запроса через HTTP-заголовок Http-Referer

на сайте, на который осуществлён переход (в том случае, если сессия хранится как часть URL)
Перехватка Cookies путём внедрения JavaScript-кода на одну из страниц сайта через XSS уязвимость ресурса или дополнительные привилегии администратора
Прослушивание HTTP-трафика
Безопасность сессииУзнав идентификатор сессии, злоумышленник может получить доступ к учётной записи другого пользователя. Способы получения идентификатора:Перехватка GET-запроса

Слайд 14Безопасность сессии
Существуют следующие методы обеспечения безопасности сессии:
Запрет на хранение идентификатора

сессии в части URL (только в Cookies)
Экранирование символов, способных внедрить

HTML-код на страницу (можно использовать функцию htmlspecialchars())
Использование протокола SSL над HTTP
Безопасность сессииСуществуют следующие методы обеспечения безопасности сессии:Запрет на хранение идентификатора сессии в части URL (только в Cookies)Экранирование

Слайд 15Другие технологии защиты сессии
Ограничение срока действия сессии
Привязка к IP-адресу пользователя,

его браузеру и другим характеристикам

Другие технологии защиты сессииОграничение срока действия сессииПривязка к IP-адресу пользователя, его браузеру и другим характеристикам

Слайд 16Функция md5()
string md5 ( string $str )
Вычисляет MD5-хэш строки str

используя алгоритм MD5 RSA Data Security, Inc. и возвращает этот

хэш.
$str = 'яблоко';

if (md5($str) === '1afa148eb41f2e7103f21410bf48346c') {
echo "Вам зеленое или красное яблоко?";
}
?>

Функция md5()string md5 ( string $str )Вычисляет MD5-хэш строки str используя алгоритм MD5 RSA Data Security, Inc.

Слайд 17Лабораторная работа
Создать скрипт авторизации пользователя на сайте при помощи сессий
Создать

форму авторизации (логин и пароль)
Реализовать алгоритм авторизации, сопоставляя данные с

теми, которые установлены внутри файла скрипта.
Пароль хранить в переменной, предварительно зашифровав значение при помощи функции md5().

Лабораторная работаСоздать скрипт авторизации пользователя на сайте при помощи сессийСоздать форму авторизации (логин и пароль)Реализовать алгоритм авторизации,

Обратная связь

Если не удалось найти и скачать доклад-презентацию, Вы можете заказать его на нашем сайте. Мы постараемся найти нужный Вам материал и отправим по электронной почте. Не стесняйтесь обращаться к нам, если у вас возникли вопросы или пожелания:

Email: Нажмите что бы посмотреть 

Что такое TheSlide.ru?

Это сайт презентации, докладов, проектов в PowerPoint. Здесь удобно  хранить и делиться своими презентациями с другими пользователями.


Для правообладателей

Яндекс.Метрика