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 lze použít k implementaci funkcí, 5 00:00:10,920 --> 00:00:13,440 jako je přihlášení uživatele, ve Vašem webovém aplikace. 6 00:00:13,440 --> 00:00:16,920 PHP sessions vám umožní přiřadit informace 7 00:00:16,920 --> 00:00:19,680 s celou relaci uživatele 8 00:00:19,680 --> 00:00:22,290 spíše než jen jednu stránku. 9 00:00:22,290 --> 00:00:27,330 Takže to znamená, že jako uživatel navštíví různé stránky s PHP, které tvoří vaše webové stránky, 10 00:00:27,330 --> 00:00:30,630 veškeré informace v relaci bude přetrvávat. 11 00:00:30,630 --> 00:00:34,770 To znamená, že data uložená v relaci o jednu stranu 12 00:00:34,770 --> 00:00:37,580 může být později přistupovat jinou stránku. 13 00:00:37,580 --> 00:00:40,080 Uložení informací v relaci je snadné, 14 00:00:40,080 --> 00:00:48,790 a my tak učinit prostřednictvím znak dolaru, podtržítko, kapitál SESSION proměnné. 15 00:00:48,790 --> 00:00:52,620 Znak dolaru, podtržítko, SESSION, stejně jako znak dolaru, podtržítko, GET 16 00:00:52,620 --> 00:00:54,710 a znak dolaru, podtržítko, POST- 17 00:00:54,710 --> 00:00:58,690 je asociativní pole se skládá z klíče a hodnoty. 18 00:00:58,690 --> 00:01:07,980 Takže můžeme použít syntax, jako znak dolaru, podtržítko, SESSION, 19 00:01:07,980 --> 00:01:16,000 držák, citace, foo, citace, držák, rovná, citace, bar, citace- 20 00:01:16,000 --> 00:01:20,440 uložit hodnotu "bar" na klíč "foo". 21 00:01:20,440 --> 00:01:24,030 Nicméně předtím, než můžeme psát nebo číst z pole zasedání, 22 00:01:24,030 --> 00:01:26,770 budeme muset zavolat speciální funkci- 23 00:01:26,770 --> 00:01:34,690 sezení, podtržítko, start () - 24 00:01:34,690 --> 00:01:37,060 a to bude inicializovat relaci. 25 00:01:37,060 --> 00:01:39,850 Takže pojďme se podívat na příklad. 26 00:01:39,850 --> 00:01:46,570 Naše první strana, hello.php, používá relace výstupu některé údaje pro uživatele. 27 00:01:46,570 --> 00:01:53,920 Pamatujte si, že budeme muset použít session_start, než budeme moci přístup k datům relace. 28 00:01:53,920 --> 00:01:59,010 Teď jsme pomocí PHP isset určit, zda existuje klíč 29 00:01:59,010 --> 00:02:03,230 v $ _SESSION asociativního pole. 30 00:02:03,230 --> 00:02:07,250 Existuje-li, že klíč, to znamená, že má uživatel přihlášen, 31 00:02:07,250 --> 00:02:10,410 takže budeme zobrazí jméno uživatele. 32 00:02:10,410 --> 00:02:14,110 Pokud není nastavena, že klíč, to znamená, že uživatel není přihlášen ještě, 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 pojďme se podívat na login.php. 35 00:02:21,380 --> 00:02:26,260 Tady dole, máme jeden HTML formulář s jedním vstupem. 36 00:02:26,260 --> 00:02:32,720 Formulář je akční atribut je $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 a to jednoduše znamená, že chceme, aby forma mají být předloženy do aktuálního souboru, 38 00:02:37,440 --> 00:02:41,040 , které, v tomto případě, je login.php. 39 00:02:41,040 --> 00:02:43,010 Takže se vraťme na začátek tohoto souboru. 40 00:02:43,010 --> 00:02:50,100 Pokud uživatel předložil vyplněný formulář, pak $ _POST ['name'] musí být nastaven. 41 00:02:50,100 --> 00:02:53,750 Pro více informací o HTML formulářů a místo, 42 00:02:53,750 --> 00:02:56,510 podívejte se na PHP Web Development videa. 43 00:02:56,510 --> 00:02:59,330 V případě, že uživatel udělal odeslání formuláře, 44 00:02:59,330 --> 00:03:03,970 bychom chtěli zapsat hodnotu, že zadali v do relace. 45 00:03:03,970 --> 00:03:08,540 Nyní můžeme přesměrovat uživatele na hello.php. 46 00:03:08,540 --> 00:03:11,800 Vzhledem k tomu, že jsme uložené vstup uživatele do relace, 47 00:03:11,800 --> 00:03:18,240 hello.php bude mít přístup k hodnotě, která byla nastavena v login.php. 48 00:03:18,240 --> 00:03:21,010 Takže pojďme se podívat na to ve webovém prohlížeči. 49 00:03:21,010 --> 00:03:27,520 Za prvé, budeme navigovat na http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Vidíme zde, že jsme nepřihlášen ještě, 51 00:03:30,220 --> 00:03:35,040 tak se pojďme klikněte na odkaz pro přihlášení, která nás bude přesměrovat na login.php. 52 00:03:35,040 --> 00:03:41,760 Dobře, budu psát své jméno, které pak budou uloženy v relaci. 53 00:03:41,760 --> 00:03:48,950 Skvělé! Nyní můžeme vidět můj vstup z login.php na hello.php prostřednictvím relace. 54 00:03:48,950 --> 00:03:52,270 Takže, co odhlášení uživatele z? 55 00:03:52,270 --> 00:03:58,510 No, aby se přihlášení uživatele v, jednoduše skladovat hodnotu do názvu relace. 56 00:03:58,510 --> 00:04:03,040 Takže pro přihlášení uživatele se, my prostě potřebujeme odstranit, že název klíče 57 00:04:03,040 --> 00:04:05,040 z pole relace. 58 00:04:05,040 --> 00:04:09,130 Takže pojďme se podívat na tento posledního souboru, logout.php. 59 00:04:09,130 --> 00:04:12,080 Opět budeme muset volat session_start () 60 00:04:12,080 --> 00:04:15,260 předtím, než můžeme dělat cokoliv relace související. 61 00:04:15,260 --> 00:04:19,240 Nyní můžeme jednoduše volat session_destroy (), 62 00:04:19,240 --> 00:04:22,460 který se bude starat, jak se zbavit všech dat na zasedání 63 00:04:22,460 --> 00:04:26,790 a pak přesměruje uživatele zpět do hello.php. 64 00:04:26,790 --> 00:04:30,700 Takže když jsem klikněte na odkaz Odhlásit, 65 00:04:30,700 --> 00:04:34,690 můžeme vidět, že server zapomněl, kdo jsem, 66 00:04:34,690 --> 00:04:36,970 a já jsem již přihlášeni 67 00:04:36,970 --> 00:04:39,910 Takže to, co se tady děje pod kapotou? 68 00:04:39,910 --> 00:04:42,250 S cílem získat chování jsme právě viděli, 69 00:04:42,250 --> 00:04:44,760 Náš server je třeba udělat dvě věci. 70 00:04:44,760 --> 00:04:48,980 Za prvé, server musí nějakým způsobem ukládat data v relaci. 71 00:04:48,980 --> 00:04:51,910 Různé PHP soubory, které tvoří webové stránky 72 00:04:51,910 --> 00:04:56,500 jsou provedeny jako samostatné vyvolání PHP interpretru 73 00:04:56,500 --> 00:05:00,550 takže lokální proměnná nemůže být sdílena mezi nimi. 74 00:05:00,550 --> 00:05:04,030 Místo toho, server musí ukládat naše data relace 75 00:05:04,030 --> 00:05:08,440 na nějakém místě, které více. php soubory mohou přistupovat. 76 00:05:08,440 --> 00:05:13,940 Za druhé, potřebuje server spojovat data relace s jedinou mou relaci. 77 00:05:13,940 --> 00:05:15,940 Když jsem se přihlásit na Facebook, 78 00:05:15,940 --> 00:05:20,460 tam jsou asi miliony dalších lidí také přihlášeni do Facebooku najednou. 79 00:05:20,460 --> 00:05:24,200 Ale server potřebuje nějaký způsob, sdružující své údaje 80 00:05:24,200 --> 00:05:28,340 s mou aktuální relace a údaje někdo jiný s jinou relaci. 81 00:05:28,340 --> 00:05:32,380 Naštěstí autoři PHP myslel o tom všem to pro nás, 82 00:05:32,380 --> 00:05:35,170 takže se není třeba provádět nic z toho sami. 83 00:05:35,170 --> 00:05:39,540 Ale pojďme se podívat na to, co dělá PHP ve výchozím nastavení. 84 00:05:39,540 --> 00:05:44,070 Když jsem navštívit stránku PHP obsahující session_start poprvé, 85 00:05:44,070 --> 00:05:47,930 PHP bude generovat velké náhodné hodnoty. 86 00:05:47,930 --> 00:05:53,970 Do session_destroy se nazývá nebo nemám navštívit nějaké stránky s PHP na tomto místě na chvíli, 87 00:05:53,970 --> 00:05:59,050 že náhodné a pravděpodobně jedinečná hodnota bude spojena se mnou. 88 00:05:59,050 --> 00:06:02,780 Tak server má nějaký způsob, jak identifikovat svou relaci procházení 89 00:06:02,780 --> 00:06:05,710 na rozdíl od někoho jiného. 90 00:06:05,710 --> 00:06:08,780 Můžeme se podívat na aktuální ID relace 91 00:06:08,780 --> 00:06:12,380 pomocí funkce PHP, session_id. 92 00:06:12,380 --> 00:06:17,250 Tady jsme prostě na výstupu hodnotu naší identifikátor relace. 93 00:06:17,250 --> 00:06:20,580 Takže pokud se znovu přihlásit na příkladu webové aplikace, 94 00:06:20,580 --> 00:06:25,530 a nyní přejděte na sessid.php, 95 00:06:25,530 --> 00:06:27,850 uvidíme, tento dlouhý řetězec znaků, 96 00:06:27,850 --> 00:06:31,180 a to je aktuální identifikátor pro mou zasedání, 97 00:06:31,180 --> 00:06:35,410 a to, jak je server sledování, kdo jsem. 98 00:06:35,410 --> 00:06:37,670 Dobře, ale my jsme jen vyřešit polovinu problému. 99 00:06:37,670 --> 00:06:40,910 Jistě, server má nyní nějaký způsob, jak mě identifikaci, 100 00:06:40,910 --> 00:06:46,060 ale když jsem se navštívit jinou stránku, server potřebuje znovu ten stejný identifikátor 101 00:06:46,060 --> 00:06:48,910 spíše než vytvářet nové. 102 00:06:48,910 --> 00:06:52,760 Pamatujte si, že když jsem deklarovat lokální proměnné v foo.php 103 00:06:52,760 --> 00:06:55,190 a pak navštivte bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php nemá žádný způsob, jak zjistit, co se stalo v foo.php. 105 00:07:00,980 --> 00:07:07,450 Takže implementace sezení výchozí php vyžaduje, aby prohlížeč připomněl server 106 00:07:07,450 --> 00:07:09,740 což ID relace použít. 107 00:07:09,740 --> 00:07:12,710 To je realizováno v podobě cookie. 108 00:07:12,710 --> 00:07:15,370 Cookie-kromě toho, že chutné občerstvení 109 00:07:15,370 --> 00:07:18,630 je prostě malý textový soubor v počítači 110 00:07:18,630 --> 00:07:21,780 že server může psát prostřednictvím webového prohlížeče. 111 00:07:21,780 --> 00:07:27,300 Takže poté, co PHP generuje svůj unikátní ID relace pomocí session_start, 112 00:07:27,300 --> 00:07:34,210 to bude vyprávět webový prohlížeč pro uložení, že identifikátor v místním textovém souboru nebo souboru cookie. 113 00:07:34,210 --> 00:07:38,490 Pak webový prohlížeč bude obsahovat tento identifikátor každé žádosti 114 00:07:38,490 --> 00:07:40,780 že je na server. 115 00:07:40,780 --> 00:07:44,280 Takže opravdu, webový server není vzpomněl, kdo jsem. 116 00:07:44,280 --> 00:07:48,780 Místo toho, webový prohlížeč je jednoduše pamatovat jedinečný identifikátor 117 00:07:48,780 --> 00:07:52,730 , který byl vytvořen pomocí PHP a neustále připomínat server 118 00:07:52,730 --> 00:07:55,120 co to je identifikátor. 119 00:07:55,120 --> 00:08:00,760 Tak, informace, stejně jako mé uživatelské jméno je uložen na serveru, nikoli můj webovém prohlížeči. 120 00:08:00,760 --> 00:08:05,190 Prohlížeč jednoduše říká serveru, kde PHP uložené informace 121 00:08:05,190 --> 00:08:07,750 takže PHP může načíst. 122 00:08:07,750 --> 00:08:12,150 Tak to vyvolává otázku, kde je PHP vlastně ukládání těchto informací? 123 00:08:12,150 --> 00:08:14,910 Ve výchozím nastavení PHP bude ukládat vaše data relace 124 00:08:14,910 --> 00:08:19,540 v souboru uvnitř z / tmp nebo složky "temp". 125 00:08:19,540 --> 00:08:24,450 Název tohoto souboru bude obsahovat ID relace, takže PHP může určit, 126 00:08:24,450 --> 00:08:28,620 který soubor pro čtení a zápis z pouze pomocí ID relace. 127 00:08:28,620 --> 00:08:32,280 Dobrá. Takže pojďme otevřít na kartu Síť v Chrome debuggeru 128 00:08:32,280 --> 00:08:34,890 přes ikonu klíče v pravém horním rohu. 129 00:08:34,890 --> 00:08:38,409 Nyní pojďme hlavu znovu hello.php. 130 00:08:38,409 --> 00:08:42,270 Pojďme klikněte na požadavku HTTP hello.php 131 00:08:42,270 --> 00:08:44,680 a poté klikněte na záhlaví. 132 00:08:44,680 --> 00:08:50,390 Zde můžeme vidět, že záhlaví cookie obsahuje klíč s názvem PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 nebo PHP ID relace, s hodnotou, která je, že stejný dlouhý řetězec viděli jsme 134 00:08:55,980 --> 00:08:59,290 když jsme navštívili sessid.php. 135 00:08:59,290 --> 00:09:04,660 To je přesně tak, jak prohlížeč připomněl server, co ID relace by měly být použity. 136 00:09:04,660 --> 00:09:08,180 Je to včetně to v hlavičce HTTP. 137 00:09:08,180 --> 00:09:10,500 Dobrá. Pojďme zpět k terminálu. 138 00:09:10,500 --> 00:09:16,450 Pojďme přejděte do adresáře / tmp, kde PHP je ukládání informací o relaci ve výchozím nastavení. 139 00:09:16,450 --> 00:09:19,160 Opravdu, v této dočasné složky, 140 00:09:19,160 --> 00:09:23,550 Zde je soubor, který obsahuje přesně stejný ID relace. 141 00:09:23,550 --> 00:09:28,990 Pokud bychom otevřít tento soubor, můžeme vidět, jak PHP reprezentuje svou relaci na disku. 142 00:09:28,990 --> 00:09:32,870 Zde řetězec "Tommy" je uložena na klíče "jméno" 143 00:09:32,870 --> 00:09:35,750 což je přesně to, co jsme očekávali. 144 00:09:35,750 --> 00:09:38,850 A to je přehled sezení v PHP. 145 00:09:38,850 --> 00:09:42,590 To, co jsme právě viděli jen Výchozí implementace sezení. 146 00:09:42,590 --> 00:09:45,600 Ve skutečnosti, mnoho internetových stránek změnit toto výchozí chování 147 00:09:45,600 --> 00:09:48,280 efektivněji ukládat PHP zasedání 148 00:09:48,280 --> 00:09:50,390 v zájmu zlepšení výkonu. 149 00:09:50,390 --> 00:09:52,800 Jmenuji se Tommy, a to je CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]