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]