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 и знакот за долар, долни, пост- 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 заградата, цитат, foo, цитат, држач еднаква, цитат, бар, понуда- 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 Кога ќе се најавите на Фејсбук, 78 00:05:15,940 --> 00:05:20,460 постојат веројатно милиони други луѓе, исто така, најавени на Фејсбук во исто време. 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 Ние можеме да ги разгледаме во тековната сесија ИД 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, или "temp" папка. 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 Во ред е. Па ајде отвори јазичето мрежа во дебагерот Хром 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 Ако ние се отвори оваа датотека, можеме да видиме како PHP е претставувајќи мојата сесија на дискот. 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]