1 00:00:00,000 --> 00:00:02,000 [Powered by Google Translate] [PHP Сессии] 2 00:00:02,000 --> 00:00:04,000 [Томми MacWilliam, Гарвардский университет] 3 00:00:04,000 --> 00:00:07,000 [Это CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Сеансы в PHP может быть использован для реализации функциональности, 5 00:00:10,920 --> 00:00:13,440 как пользовательских логинов, в вашем веб-приложение. 6 00:00:13,440 --> 00:00:16,920 PHP сессии позволяют связать информацию 7 00:00:16,920 --> 00:00:19,680 со всей сеанса просмотра пользователя 8 00:00:19,680 --> 00:00:22,290 а не просто одной странице. 9 00:00:22,290 --> 00:00:27,330 Значит, как пользователь посещает различные PHP-страниц, составляющих ваш сайт, 10 00:00:27,330 --> 00:00:30,630 любая информация, в заседании будет сохраняться. 11 00:00:30,630 --> 00:00:34,770 Таким образом, это означает, что данные, хранимые в сессии на одну страницу 12 00:00:34,770 --> 00:00:37,580 может позже быть доступны другую страницу. 13 00:00:37,580 --> 00:00:40,080 Хранение информации в сеансе легко, 14 00:00:40,080 --> 00:00:48,790 и мы делаем это с помощью знака доллара, подчеркивания, переменный капитал сессии. 15 00:00:48,790 --> 00:00:52,620 Знак доллара, подчеркивания, СЕССИЯ-так же, как знак доллара, подчеркивания, GET 16 00:00:52,620 --> 00:00:54,710 и знак доллара, подчеркивания, POST- 17 00:00:54,710 --> 00:00:58,690 представляет собой ассоциативный массив, состоящий из пар ключ-значение. 18 00:00:58,690 --> 00:01:07,980 Таким образом, мы можем использовать синтаксис, как знак доллара, подчеркивания, сессия, 19 00:01:07,980 --> 00:01:16,000 кронштейн, цитаты, Фу, цитаты, кронштейн, равно, цитаты, бар, цитата- 20 00:01:16,000 --> 00:01:20,440 для хранения значения "бар" в ключевом "Foo". 21 00:01:20,440 --> 00:01:24,030 Однако, прежде чем мы можем писать или читать из массива сессии, 22 00:01:24,030 --> 00:01:26,770 мы должны будем назвать специальную функцию- 23 00:01:26,770 --> 00:01:34,690 сессия, подчеркивают, начать, () - 24 00:01:34,690 --> 00:01:37,060 и это будет инициализировать сеанс. 25 00:01:37,060 --> 00:01:39,850 Итак, давайте посмотрим на примере. 26 00:01:39,850 --> 00:01:46,570 Наша первая страница, hello.php, использует сессию для вывода некоторые данные для пользователя. 27 00:01:46,570 --> 00:01:53,920 Помните, мы должны будем использовать session_start прежде чем мы сможем получить доступ к любому данных сеанса. 28 00:01:53,920 --> 00:01:59,010 Теперь мы используем Isset PHP, чтобы определить, существует ли ключ 29 00:01:59,010 --> 00:02:03,230 в $ _SESSION ассоциативный массив. 30 00:02:03,230 --> 00:02:07,250 Если этот ключ существует, это означает, что пользователь вошел в систему, 31 00:02:07,250 --> 00:02:10,410 поэтому мы будем отображать имя пользователя. 32 00:02:10,410 --> 00:02:14,110 Если этот ключ не установлен, это означает, что пользователь не вошли в ранее, 33 00:02:14,110 --> 00:02:17,880 поэтому мы будем отображать ссылку на login.php. 34 00:02:17,880 --> 00:02:21,380 Так что давайте взглянем на login.php. 35 00:02:21,380 --> 00:02:26,260 Здесь, внизу, у нас есть один вид HTML с одним входом. 36 00:02:26,260 --> 00:02:32,720 Атрибут действия формы составляет $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 и это просто означает, что мы хотим, чтобы форма для представления текущего файла, 38 00:02:37,440 --> 00:02:41,040 который, в данном случае, является login.php. 39 00:02:41,040 --> 00:02:43,010 Так давайте вернемся к началу этого файла. 40 00:02:43,010 --> 00:02:50,100 Если пользователь представил форму, то $ _POST ['имя'] должен быть установлен. 41 00:02:50,100 --> 00:02:53,750 Дополнительные сведения о HTML форм и должности, 42 00:02:53,750 --> 00:02:56,510 проверить видео Веб-разработка PHP. 43 00:02:56,510 --> 00:02:59,330 В случае, когда пользователь сделал представить форму, 44 00:02:59,330 --> 00:03:03,970 мы хотели бы, чтобы записать значение, что они ввели в в сессии. 45 00:03:03,970 --> 00:03:08,540 Теперь мы можем перенаправить пользователя на hello.php. 46 00:03:08,540 --> 00:03:11,800 Потому что мы сохранили вход пользователя в сессии, 47 00:03:11,800 --> 00:03:18,240 hello.php смогут получить доступ к значению, которое было установлено в login.php. 48 00:03:18,240 --> 00:03:21,010 Так что давайте проверить это в веб-браузере. 49 00:03:21,010 --> 00:03:27,520 Во-первых, мы будем ориентироваться на http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Мы видим здесь, что мы не вошли в ранее, 51 00:03:30,220 --> 00:03:35,040 так что давайте нажать на ссылку для входа, который будет перенаправлять нас к login.php. 52 00:03:35,040 --> 00:03:41,760 Хорошо, я буду ввести свое имя, которое затем будет храниться в сессии. 53 00:03:41,760 --> 00:03:48,950 Отлично! Теперь мы можем видеть мой ввод от login.php на hello.php через сессии. 54 00:03:48,950 --> 00:03:52,270 Итак, что же о входе пользователя вне дома? 55 00:03:52,270 --> 00:03:58,510 Ну, для того, чтобы войти пользователю в, мы просто хранить значение в имени сеанса. 56 00:03:58,510 --> 00:04:03,040 Таким образом, чтобы войти пользователю, мы просто должны удалить этот ключ имя 57 00:04:03,040 --> 00:04:05,040 из массива сеанса. 58 00:04:05,040 --> 00:04:09,130 Так что давайте взглянем на этот последний файл, logout.php. 59 00:04:09,130 --> 00:04:12,080 Еще раз, мы должны будем вызываете session_start () 60 00:04:12,080 --> 00:04:15,260 прежде чем мы сможем сделать что-нибудь сессии связаны между собой. 61 00:04:15,260 --> 00:04:19,240 Теперь мы можем просто позвонить session_destroy (), 62 00:04:19,240 --> 00:04:22,460 который будет заботиться об избавлении от всех данных в сессии 63 00:04:22,460 --> 00:04:26,790 а затем перенаправить пользователя обратно в hello.php. 64 00:04:26,790 --> 00:04:30,700 Так что, если я нажимаю на ссылку Выйти, 65 00:04:30,700 --> 00:04:34,690 мы видим, что сервер забыл, кто я, 66 00:04:34,690 --> 00:04:36,970 не, и я больше не зашли 67 00:04:36,970 --> 00:04:39,910 Так что здесь происходит под капотом? 68 00:04:39,910 --> 00:04:42,250 Для того, чтобы получить информацию о поведении мы только что видели, 69 00:04:42,250 --> 00:04:44,760 наш сервер должен сделать 2 вещи. 70 00:04:44,760 --> 00:04:48,980 Во-первых, сервер должен как-то хранить данные в сессии. 71 00:04:48,980 --> 00:04:51,910 Различные файлы PHP, которые содержат сайт 72 00:04:51,910 --> 00:04:56,500 выполнены в виде отдельных вызовов интерпретатора PHP 73 00:04:56,500 --> 00:05:00,550 так локальная переменная не может быть разделена между ними. 74 00:05:00,550 --> 00:05:04,030 Вместо этого сервер должен хранить наши данные сессии 75 00:05:04,030 --> 00:05:08,440 в каком-то месте, что множественные. файлы PHP может получить доступ. 76 00:05:08,440 --> 00:05:13,940 Во-вторых, сервер должен связать данные сеанса только с моей сеанса просмотра. 77 00:05:13,940 --> 00:05:15,940 После авторизации, я Facebook, 78 00:05:15,940 --> 00:05:20,460 Есть, вероятно, миллионы других людей также зарегистрированы в Facebook, в то же время. 79 00:05:20,460 --> 00:05:24,200 Но сервер необходим способ связывания мои данные 80 00:05:24,200 --> 00:05:28,340 с моей нынешней сессии и данных чужой с другой сессии. 81 00:05:28,340 --> 00:05:32,380 К счастью, авторы PHP думал обо всем этом для нас, 82 00:05:32,380 --> 00:05:35,170 так что мы не должны реализовать все это сами. 83 00:05:35,170 --> 00:05:39,540 Но давайте взглянем на то, что PHP делает по умолчанию. 84 00:05:39,540 --> 00:05:44,070 Когда я посещаю страницу PHP, содержащий session_start впервые, 85 00:05:44,070 --> 00:05:47,930 PHP будет генерировать большое случайное значение. 86 00:05:47,930 --> 00:05:53,970 До session_destroy не называется-или я не посещаю никаких PHP-страниц на этом сайте на некоторое время- 87 00:05:53,970 --> 00:05:59,050 что случайная и, вероятно, уникальное значение будет ассоциироваться со мной. 88 00:05:59,050 --> 00:06:02,780 Таким образом, сервер имеет какой-то способ идентификации мой сеанса просмотра 89 00:06:02,780 --> 00:06:05,710 в отличие от чужое. 90 00:06:05,710 --> 00:06:08,780 Мы можем взглянуть на нынешней сессии ID 91 00:06:08,780 --> 00:06:12,380 с помощью функции PHP, SESSION_ID. 92 00:06:12,380 --> 00:06:17,250 Здесь мы просто выводит значение нашего идентификатором сеанса. 93 00:06:17,250 --> 00:06:20,580 Так что если мы снова войти в примере веб-приложение, 94 00:06:20,580 --> 00:06:25,530 и теперь перейдите к sessid.php, 95 00:06:25,530 --> 00:06:27,850 мы увидим эту длинную строку символов, 96 00:06:27,850 --> 00:06:31,180 и это текущая идентификатор моей сессии, 97 00:06:31,180 --> 00:06:35,410 и вот как сервер является отслеживание, кто я. 98 00:06:35,410 --> 00:06:37,670 Хорошо, но мы только решить половину проблемы. 99 00:06:37,670 --> 00:06:40,910 Конечно, сервер теперь имеет какой-то способ идентификации меня, 100 00:06:40,910 --> 00:06:46,060 но, когда я посещаю другую страницу, сервер должен повторно использовать этот же идентификатор 101 00:06:46,060 --> 00:06:48,910 , а не генерации нового. 102 00:06:48,910 --> 00:06:52,760 Помните, что если я объявить локальную переменную в foo.php 103 00:06:52,760 --> 00:06:55,190 а затем посетить bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php не имеет возможности узнать, что произошло в foo.php. 105 00:07:00,980 --> 00:07:07,450 Так реализация сессия по умолчанию PHP требует, чтобы браузер напомнить сервер 106 00:07:07,450 --> 00:07:09,740 которые идентификатор сеанса в использовании. 107 00:07:09,740 --> 00:07:12,710 Это реализовано в виде куки. 108 00:07:12,710 --> 00:07:15,370 Печенья в дополнение к тому, вкусные закуски- 109 00:07:15,370 --> 00:07:18,630 просто это небольшой текстовый файл на вашем компьютере 110 00:07:18,630 --> 00:07:21,780 что сервер может написать через веб-браузер. 111 00:07:21,780 --> 00:07:27,300 Таким образом, после PHP генерирует свой уникальный идентификатор сеанса через session_start, 112 00:07:27,300 --> 00:07:34,210 он собирается рассказать веб-браузер для хранения этот идентификатор в локальном текстовом файле или печенье. 113 00:07:34,210 --> 00:07:38,490 Тогда веб-браузер будет включать в себя этот идентификатор в каждом запросе 114 00:07:38,490 --> 00:07:40,780 что это делает к серверу. 115 00:07:40,780 --> 00:07:44,280 Так на самом деле, веб-сервер не помня, кто я. 116 00:07:44,280 --> 00:07:48,780 Вместо этого, веб-браузер просто помня уникальный идентификатор 117 00:07:48,780 --> 00:07:52,730 , который был создан на PHP, а затем постоянно напоминая сервер 118 00:07:52,730 --> 00:07:55,120 что это идентификатор. 119 00:07:55,120 --> 00:08:00,760 Таким образом, информация, как мое имя пользователя хранится на сервере не мой веб-браузер. 120 00:08:00,760 --> 00:08:05,190 Браузер просто сообщает серверу, где PHP хранимую эту информацию 121 00:08:05,190 --> 00:08:07,750 так PHP сможет его восстановить. 122 00:08:07,750 --> 00:08:12,150 Так что возникает вопрос, где PHP на самом деле хранения этой информации? 123 00:08:12,150 --> 00:08:14,910 По умолчанию, PHP будет хранить данные сеанса 124 00:08:14,910 --> 00:08:19,540 в файле внутри / TMP или папке 'Темп'. 125 00:08:19,540 --> 00:08:24,450 Имя этого файла будет включать идентификатор сеанса так PHP можно определить 126 00:08:24,450 --> 00:08:28,620 какой файл для чтения и записи с помощью только идентификатор сеанса. 127 00:08:28,620 --> 00:08:32,280 Хорошо. Так давайте откроем вкладку Сеть отладчик в Chrome 128 00:08:32,280 --> 00:08:34,890 через значок гаечного ключа в правом верхнем углу. 129 00:08:34,890 --> 00:08:38,409 Теперь давайте голову к hello.php снова. 130 00:08:38,409 --> 00:08:42,270 Давайте нажмем на запрос HTTP, чтобы hello.php 131 00:08:42,270 --> 00:08:44,680 а затем нажмите на заголовки. 132 00:08:44,680 --> 00:08:50,390 Здесь мы можем видеть, что заголовок печенье содержит ключ с именем PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 или PHP идентификатор сеанса-со значением, которое в тот же длинная строка мы видели 134 00:08:55,980 --> 00:08:59,290 когда мы посетили sessid.php. 135 00:08:59,290 --> 00:09:04,660 Это именно то, как браузер напоминает серверу, что идентификатор сеанса следует использовать. 136 00:09:04,660 --> 00:09:08,180 Это в том числе его в заголовке HTTP. 137 00:09:08,180 --> 00:09:10,500 Хорошо. Давайте голову обратно на терминал. 138 00:09:10,500 --> 00:09:16,450 Давайте перейдите к / TMP, где PHP хранит информацию о сеансе по умолчанию. 139 00:09:16,450 --> 00:09:19,160 Конечно же, внутри этого временную папку, 140 00:09:19,160 --> 00:09:23,550 вот это файл, который содержит ту же самую точную идентификатор сеанса. 141 00:09:23,550 --> 00:09:28,990 Если мы открываем этот файл, мы можем увидеть, как РНР представлять свою сессию на диске. 142 00:09:28,990 --> 00:09:32,870 Вот строка "Томми" находится на хранении ключом «имя», 143 00:09:32,870 --> 00:09:35,750 а это именно то, что мы ожидали. 144 00:09:35,750 --> 00:09:38,850 И это обзор сессий в PHP. 145 00:09:38,850 --> 00:09:42,590 То, что мы только что видели только реализация по умолчанию сессий. 146 00:09:42,590 --> 00:09:45,600 На самом деле, многие веб-сайты изменить это поведение по умолчанию 147 00:09:45,600 --> 00:09:48,280 более эффективно хранить PHP сессий 148 00:09:48,280 --> 00:09:50,390 в интересах повышения производительности. 149 00:09:50,390 --> 00:09:52,800 Меня зовут Томми, и это CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]