1 00:00:00,000 --> 00:00:02,000 [Powered by Google Translate] [PHP Sessions] 2 00:00:02,000 --> 00:00:04,000 [Tommy MacWilliam, Harvard University] 3 00:00:04,000 --> 00:00:07,000 [To je CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Sessions v PHP možno použiť na implementáciu funkcií, 5 00:00:10,920 --> 00:00:13,440 ako je prihlásenie užívateľa, vo Vašom webovom aplikácie. 6 00:00:13,440 --> 00:00:16,920 PHP sessions vám umožní priradiť informácie 7 00:00:16,920 --> 00:00:19,680 s celou relácii užívateľa 8 00:00:19,680 --> 00:00:22,290 skôr než len jednu stránku. 9 00:00:22,290 --> 00:00:27,330 Takže to znamená, že ako používateľ navštívi rôzne stránky s PHP, ktoré tvoria vaše webové stránky, 10 00:00:27,330 --> 00:00:30,630 všetky informácie v relácii bude pretrvávať. 11 00:00:30,630 --> 00:00:34,770 To znamená, že dáta uložené v relácii o jednu stranu 12 00:00:34,770 --> 00:00:37,580 môže byť neskôr pristupovať inú stránku. 13 00:00:37,580 --> 00:00:40,080 Uloženie informácií v relácii je ľahké, 14 00:00:40,080 --> 00:00:48,790 a my tak urobiť prostredníctvom znak dolára, podčiarkovník, kapitál SESSION premenné. 15 00:00:48,790 --> 00:00:52,620 Znak dolára, podčiarkovník, SESSION, rovnako ako znak dolára, podčiarkovník, GET 16 00:00:52,620 --> 00:00:54,710 a znak dolára, podčiarkovník, POST- 17 00:00:54,710 --> 00:00:58,690 je asociatívne pole sa skladá z kľúča a hodnoty. 18 00:00:58,690 --> 00:01:07,980 Takže môžeme použiť syntax, ako znak dolára, podčiarkovník, SESSION, 19 00:01:07,980 --> 00:01:16,000 držiak, citácie, foo, citácie, držiak, rovná, citácie, bar, citácie- 20 00:01:16,000 --> 00:01:20,440 uložiť hodnotu "bar" na kľúč "foo". 21 00:01:20,440 --> 00:01:24,030 Avšak predtým, než môžeme písať alebo čítať z poľa zasadnutí, 22 00:01:24,030 --> 00:01:26,770 budeme musieť zavolať špeciálnu funkciu- 23 00:01:26,770 --> 00:01:34,690 sedenie, podčiarkovník, štart () - 24 00:01:34,690 --> 00:01:37,060 a to bude inicializovať reláciu. 25 00:01:37,060 --> 00:01:39,850 Takže poďme sa pozrieť na príklad. 26 00:01:39,850 --> 00:01:46,570 Naša prvá strana, hello.php, používa relácie výstupu niektoré údaje pre užívateľa. 27 00:01:46,570 --> 00:01:53,920 Pamätajte si, že budeme musieť použiť session_start, než budeme môcť prístup k dátam relácie. 28 00:01:53,920 --> 00:01:59,010 Teraz sme pomocou PHP isset určiť, či existuje kľúč 29 00:01:59,010 --> 00:02:03,230 v $ _SESSION asociatívneho poľa. 30 00:02:03,230 --> 00:02:07,250 Existuje-li, že kľúč, to znamená, že má používateľ prihlásený, 31 00:02:07,250 --> 00:02:10,410 takže budeme zobrazí meno užívateľa. 32 00:02:10,410 --> 00:02:14,110 Ak nie je nastavená, že kľúč, to znamená, že užívateľ nie je prihlásený ešte, 33 00:02:14,110 --> 00:02:17,880 takže budeme zobrazí odkaz na login.php. 34 00:02:17,880 --> 00:02:21,380 Takže poďme sa pozrieť na login.php. 35 00:02:21,380 --> 00:02:26,260 Tu dole, máme jeden HTML formulár s jedným vstupom. 36 00:02:26,260 --> 00:02:32,720 Formulár je akčná atribút je $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 a to jednoducho znamená, že chceme, aby forma majú byť predložené do aktuálneho súboru, 38 00:02:37,440 --> 00:02:41,040 , Ktoré, v tomto prípade, je login.php. 39 00:02:41,040 --> 00:02:43,010 Takže sa vráťme na začiatok tohto súboru. 40 00:02:43,010 --> 00:02:50,100 Ak užívateľ predložil vyplnený formulár, potom $ _POST ['name'] musí byť nastavený. 41 00:02:50,100 --> 00:02:53,750 Pre viac informácií o HTML formulárov a miesto, 42 00:02:53,750 --> 00:02:56,510 pozrite sa na PHP Web Development videa. 43 00:02:56,510 --> 00:02:59,330 V prípade, že užívateľ urobil odoslaní formulára, 44 00:02:59,330 --> 00:03:03,970 by sme chceli zapísať hodnotu, že zadali v do relácie. 45 00:03:03,970 --> 00:03:08,540 Teraz môžeme presmerovať užívateľa na hello.php. 46 00:03:08,540 --> 00:03:11,800 Vzhľadom k tomu, že sme uložené vstup užívateľa do relácie, 47 00:03:11,800 --> 00:03:18,240 hello.php bude mať prístup k hodnote, ktorá bola nastavená v login.php. 48 00:03:18,240 --> 00:03:21,010 Takže poďme sa pozrieť na to vo webovom prehliadači. 49 00:03:21,010 --> 00:03:27,520 Po prvé, budeme navigovať na http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Vidíme tu, že sme neprihlásený ešte, 51 00:03:30,220 --> 00:03:35,040 tak sa poďme kliknite na odkaz pre prihlásenie, ktorá nás bude presmerovať na login.php. 52 00:03:35,040 --> 00:03:41,760 Dobre, budem písať svoje meno, ktoré potom budú uložené v relácii. 53 00:03:41,760 --> 00:03:48,950 Skvelé! Teraz môžeme vidieť môj vstup z login.php na hello.php prostredníctvom relácie. 54 00:03:48,950 --> 00:03:52,270 Takže, čo odhlásenia užívateľa z? 55 00:03:52,270 --> 00:03:58,510 No, aby sa prihlásenie užívateľa v, jednoducho skladovať hodnotu do názvu relácie. 56 00:03:58,510 --> 00:04:03,040 Takže pre prihlásenie užívateľa sa, my jednoducho potrebujeme odstrániť, že názov kľúče 57 00:04:03,040 --> 00:04:05,040 z poľa relácie. 58 00:04:05,040 --> 00:04:09,130 Takže poďme sa pozrieť na tento posledného súboru, logout.php. 59 00:04:09,130 --> 00:04:12,080 Opäť budeme musieť volať session_start () 60 00:04:12,080 --> 00:04:15,260 predtým, než môžeme robiť čokoľvek relácie súvisiace. 61 00:04:15,260 --> 00:04:19,240 Teraz môžeme jednoducho volať session_destroy (), 62 00:04:19,240 --> 00:04:22,460 ktorý sa bude starať, ako sa zbaviť všetkých dát na zasadnutí 63 00:04:22,460 --> 00:04:26,790 a potom presmeruje užívateľa späť do hello.php. 64 00:04:26,790 --> 00:04:30,700 Takže keď som kliknite na odkaz Odhlásiť, 65 00:04:30,700 --> 00:04:34,690 môžeme vidieť, že server zabudol, kto som, 66 00:04:34,690 --> 00:04:36,970 a ja som už prihlásení 67 00:04:36,970 --> 00:04:39,910 Takže to, čo sa tu deje pod kapotou? 68 00:04:39,910 --> 00:04:42,250 S cieľom získať správanie sme práve videli, 69 00:04:42,250 --> 00:04:44,760 Náš server je potrebné urobiť dve veci. 70 00:04:44,760 --> 00:04:48,980 Po prvé, server musí nejakým spôsobom ukladať dáta v relácii. 71 00:04:48,980 --> 00:04:51,910 Rôzne PHP súbory, ktoré tvoria webové stránky 72 00:04:51,910 --> 00:04:56,500 sú vyhotovené ako samostatné vyvolanie PHP interpretru 73 00:04:56,500 --> 00:05:00,550 takže lokálna premenná nemôže byť zdieľaná medzi nimi. 74 00:05:00,550 --> 00:05:04,030 Namiesto toho, server musí ukladať naše dáta relácie 75 00:05:04,030 --> 00:05:08,440 na nejakom mieste, ktoré viac. php súbory môžu pristupovať. 76 00:05:08,440 --> 00:05:13,940 Po druhé, potrebuje server spájať dáta relácie s jedinou mojou relácii. 77 00:05:13,940 --> 00:05:15,940 Keď som sa prihlásiť na Facebook, 78 00:05:15,940 --> 00:05:20,460 tam sú asi milióny ďalších ľudí tiež prihlásený do Facebooku naraz. 79 00:05:20,460 --> 00:05:24,200 Ale server potrebuje nejaký spôsob, združujúca svoje údaje 80 00:05:24,200 --> 00:05:28,340 s mojou aktuálnej relácie a údaje niekto iný s inou relácii. 81 00:05:28,340 --> 00:05:32,380 Našťastie autori PHP myslel o tom všetkom to pre nás, 82 00:05:32,380 --> 00:05:35,170 takže sa nie je potrebné vykonávať nič z toho sami. 83 00:05:35,170 --> 00:05:39,540 Ale poďme sa pozrieť na to, čo robí PHP v predvolenom nastavení. 84 00:05:39,540 --> 00:05:44,070 Keď som navštíviť stránku PHP obsahujúce session_start prvýkrát, 85 00:05:44,070 --> 00:05:47,930 PHP bude generovať veľké náhodné hodnoty. 86 00:05:47,930 --> 00:05:53,970 Do session_destroy sa nazýva alebo nemám navštíviť nejaké stránky s PHP na tomto mieste na chvíľu, 87 00:05:53,970 --> 00:05:59,050 že náhodné a pravdepodobne jedinečná hodnota bude spojená so mnou. 88 00:05:59,050 --> 00:06:02,780 Tak server má nejaký spôsob, ako identifikovať svoju reláciu prehľadávania 89 00:06:02,780 --> 00:06:05,710 na rozdiel od niekoho iného. 90 00:06:05,710 --> 00:06:08,780 Môžeme sa pozrieť na aktuálne ID relácie 91 00:06:08,780 --> 00:06:12,380 pomocou funkcie PHP, session_id. 92 00:06:12,380 --> 00:06:17,250 Tu sme proste na výstupe hodnotu našej identifikátor relácie. 93 00:06:17,250 --> 00:06:20,580 Takže ak sa znova prihlásiť na príklade webové aplikácie, 94 00:06:20,580 --> 00:06:25,530 a teraz prejdite na sessid.php, 95 00:06:25,530 --> 00:06:27,850 uvidíme, tento dlhý reťazec znakov, 96 00:06:27,850 --> 00:06:31,180 a to je aktuálny identifikátor pre moju zasadnutie, 97 00:06:31,180 --> 00:06:35,410 a to, ako je server sledovanie, kto som. 98 00:06:35,410 --> 00:06:37,670 Dobre, ale my sme len vyriešiť polovicu problému. 99 00:06:37,670 --> 00:06:40,910 Iste, server má teraz nejaký spôsob, ako ma identifikáciu, 100 00:06:40,910 --> 00:06:46,060 ale keď som sa navštíviť inú stránku, server potrebuje znovu ten rovnaký identifikátor 101 00:06:46,060 --> 00:06:48,910 skôr než vytvárať nové. 102 00:06:48,910 --> 00:06:52,760 Pamätajte si, že keď som deklarovať lokálne premenné v foo.php 103 00:06:52,760 --> 00:06:55,190 a potom navštívte bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php nemá žiadny spôsob, ako zistiť, čo sa stalo v foo.php. 105 00:07:00,980 --> 00:07:07,450 Takže implementácia sedenie predvolené php vyžaduje, aby prehliadač pripomenul server 106 00:07:07,450 --> 00:07:09,740 čo ID relácie použiť. 107 00:07:09,740 --> 00:07:12,710 To je realizované v podobe cookie. 108 00:07:12,710 --> 00:07:15,370 Cookie-okrem toho, že chutné občerstvenie 109 00:07:15,370 --> 00:07:18,630 je jednoducho malý textový súbor v počítači 110 00:07:18,630 --> 00:07:21,780 že server môže písať prostredníctvom webového prehliadača. 111 00:07:21,780 --> 00:07:27,300 Takže potom, čo PHP generuje svoj unikátny ID relácie pomocou session_start, 112 00:07:27,300 --> 00:07:34,210 to bude rozprávať webový prehliadač pre uloženie, že identifikátor v miestnom textovom súbore alebo súboru cookie. 113 00:07:34,210 --> 00:07:38,490 Potom webový prehliadač bude obsahovať tento identifikátor každej žiadosti 114 00:07:38,490 --> 00:07:40,780 že je na server. 115 00:07:40,780 --> 00:07:44,280 Takže naozaj, webový server nie je spomenul, kto som. 116 00:07:44,280 --> 00:07:48,780 Namiesto toho, webový prehliadač je jednoducho pamätať jedinečný identifikátor 117 00:07:48,780 --> 00:07:52,730 , Ktorý bol vytvorený pomocou PHP a neustále pripomínať server 118 00:07:52,730 --> 00:07:55,120 čo to je identifikátor. 119 00:07:55,120 --> 00:08:00,760 Tak, informácie, rovnako ako moje užívateľské meno je uložený na serveri, nie môj webovom prehliadači. 120 00:08:00,760 --> 00:08:05,190 Prehliadač jednoducho hovorí serveri, kde PHP uložené informácie 121 00:08:05,190 --> 00:08:07,750 takže PHP môže načítať. 122 00:08:07,750 --> 00:08:12,150 Tak to vyvoláva otázku, kde je PHP vlastne ukladanie týchto informácií? 123 00:08:12,150 --> 00:08:14,910 V predvolenom nastavení PHP bude ukladať vaše dáta relácie 124 00:08:14,910 --> 00:08:19,540 v súbore vo vnútri z / tmp alebo zložky "temp". 125 00:08:19,540 --> 00:08:24,450 Názov tohto súboru bude obsahovať ID relácie, takže PHP môže určiť, 126 00:08:24,450 --> 00:08:28,620 ktorý súbor pre čítanie a zápis z iba pomocou ID relácie. 127 00:08:28,620 --> 00:08:32,280 Dobrá. Takže poďme otvoriť na kartu Sieť v Chrome debuggeru 128 00:08:32,280 --> 00:08:34,890 cez ikonu kľúča v pravom hornom rohu. 129 00:08:34,890 --> 00:08:38,409 Teraz poďme hlavu znovu hello.php. 130 00:08:38,409 --> 00:08:42,270 Poďme kliknite na požiadavke HTTP hello.php 131 00:08:42,270 --> 00:08:44,680 a potom kliknite na hlavičku. 132 00:08:44,680 --> 00:08:50,390 Tu môžeme vidieť, že záhlavie cookie obsahuje kľúč s názvom PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 alebo PHP ID relácie, s hodnotou, ktorá je, že rovnaký dlhý reťazec videli sme 134 00:08:55,980 --> 00:08:59,290 keď sme navštívili sessid.php. 135 00:08:59,290 --> 00:09:04,660 To je presne tak, ako prehliadač pripomenul server, čo ID relácie by mali byť použité. 136 00:09:04,660 --> 00:09:08,180 Je to vrátane to v hlavičke HTTP. 137 00:09:08,180 --> 00:09:10,500 Dobrá. Poďme späť k terminálu. 138 00:09:10,500 --> 00:09:16,450 Poďme prejdite do adresára / tmp, kde PHP je ukladanie informácií o relácii v predvolenom nastavení. 139 00:09:16,450 --> 00:09:19,160 Naozaj, v tejto dočasnej zložky, 140 00:09:19,160 --> 00:09:23,550 Tu je súbor, ktorý obsahuje presne rovnaký ID relácie. 141 00:09:23,550 --> 00:09:28,990 Ak by sme otvoriť tento súbor, môžeme vidieť, ako PHP reprezentuje svoju reláciu na disku. 142 00:09:28,990 --> 00:09:32,870 Tu reťazec "Tommy" je uložená na kľúče "meno" 143 00:09:32,870 --> 00:09:35,750 čo je presne to, čo sme očakávali. 144 00:09:35,750 --> 00:09:38,850 A to je prehľad sedenie v PHP. 145 00:09:38,850 --> 00:09:42,590 To, čo sme práve videli len Predvolené implementácie sedenie. 146 00:09:42,590 --> 00:09:45,600 V skutočnosti, mnoho internetových stránok zmeniť toto predvolené správanie 147 00:09:45,600 --> 00:09:48,280 efektívnejšie ukladať PHP zasadnutie 148 00:09:48,280 --> 00:09:50,390 v záujme zlepšenia výkonu. 149 00:09:50,390 --> 00:09:52,800 Volám sa Tommy, a to je CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]