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]