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, a Harvard Egyetem] 3 00:00:04,000 --> 00:00:07,000 [Ez a CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Sessions a PHP használható végrehajtásához funkcionalitás, 5 00:00:10,920 --> 00:00:13,440 mint például a felhasználói bejelentkezések, a web app. 6 00:00:13,440 --> 00:00:16,920 PHP ülések lehetővé teszik, hogy a társult adatok 7 00:00:16,920 --> 00:00:19,680 A felhasználó teljes böngészés 8 00:00:19,680 --> 00:00:22,290 ahelyett, hogy egyszerűen egy oldalon. 9 00:00:22,290 --> 00:00:27,330 Tehát ez azt jelenti, mint a felhasználó meglátogatja különböző PHP oldalak teszik fel a honlapon, 10 00:00:27,330 --> 00:00:30,630 minden olyan információt az ülésen továbbra is fennállnak. 11 00:00:30,630 --> 00:00:34,770 Ez azt jelenti, hogy a tárolt adatok a munkamenet egy oldallal 12 00:00:34,770 --> 00:00:37,580 később elérhető egy másik oldalra. 13 00:00:37,580 --> 00:00:40,080 Tárolja az adatokat a munkamenet egyszerű, 14 00:00:40,080 --> 00:00:48,790 és mi ezt át a dollár jelet, aláhúzás, a tőke SESSION változót. 15 00:00:48,790 --> 00:00:52,620 Dollár jelet, aláhúzás, SESSION-akárcsak dollár jelet, aláhúzás, GET 16 00:00:52,620 --> 00:00:54,710 és a dollár jelet, aláhúzás, POST- 17 00:00:54,710 --> 00:00:58,690 egy asszociatív tömb, ami kulcs-érték pár. 18 00:00:58,690 --> 00:01:07,980 Így tudjuk használni syntax-, mint a dollár jel, aláhúzás, SESSION, 19 00:01:07,980 --> 00:01:16,000 konzol, idézet, ize, idézet, konzol, egyenlő, idézet, bár, quote- 20 00:01:16,000 --> 00:01:20,440 az érték tárolásához "bar" a legfontosabb "foo". 21 00:01:20,440 --> 00:01:24,030 Mielőtt azonban írni, vagy olvasni a munkamenet tömb, 22 00:01:24,030 --> 00:01:26,770 akkor kell hívni egy speciális funkció- 23 00:01:26,770 --> 00:01:34,690 ülés, aláhúzás, start () - 24 00:01:34,690 --> 00:01:37,060 és ez inicializálja az ülésen. 25 00:01:37,060 --> 00:01:39,850 Szóval vessünk egy pillantást egy példát. 26 00:01:39,850 --> 00:01:46,570 Az első oldal, hello.php, használja a munkamenet kimenet néhány adatot a felhasználó számára. 27 00:01:46,570 --> 00:01:53,920 Ne feledje, akkor kell használni session_start előtt tudunk hozzáférni a munkamenet adatok. 28 00:01:53,920 --> 00:01:59,010 Most már a PHP isset annak meghatározására, hogy a kulcs létezik 29 00:01:59,010 --> 00:02:03,230 a $ _SESSION asszociatív tömb. 30 00:02:03,230 --> 00:02:07,250 Ha ez a kulcs létezik, azt jelenti, hogy a felhasználó bejelentkezett, 31 00:02:07,250 --> 00:02:10,410 így fogunk megjeleníti a felhasználó nevét. 32 00:02:10,410 --> 00:02:14,110 Ha ez a kulcs nincs beállítva, akkor azt jelenti, hogy a felhasználó még nem jelentkezett be még, 33 00:02:14,110 --> 00:02:17,880 így akkor megjelenik egy link login.php. 34 00:02:17,880 --> 00:02:21,380 Szóval vessünk egy pillantást login.php. 35 00:02:21,380 --> 00:02:26,260 Itt lent, van egy HTML form egyetlen input. 36 00:02:26,260 --> 00:02:32,720 Az űrlap akció attribútum $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 és ez egyszerűen azt jelenti, hogy szeretnénk az űrlapot kell benyújtani az aktuális kép, 38 00:02:37,440 --> 00:02:41,040 ami ebben az esetben login.php. 39 00:02:41,040 --> 00:02:43,010 Akkor menjünk vissza a tetejére ezt a fájlt. 40 00:02:43,010 --> 00:02:50,100 Ha a felhasználó a formában, akkor a $ _POST ['name'] be kell állítani. 41 00:02:50,100 --> 00:02:53,750 További információ a HTML formában és postai úton, 42 00:02:53,750 --> 00:02:56,510 nézd meg a PHP Web Development video. 43 00:02:56,510 --> 00:02:59,330 Abban az esetben, ha a felhasználó nem nyújt be az űrlapot, 44 00:02:59,330 --> 00:03:03,970 szeretnénk írni, az értéket, hogy a beírt az ülésen. 45 00:03:03,970 --> 00:03:08,540 Most már tudjuk átirányítani a felhasználót hello.php. 46 00:03:08,540 --> 00:03:11,800 Mert már tárolt a felhasználó viszi be az ülés, 47 00:03:11,800 --> 00:03:18,240 hello.php képes lesz elérni az értéket, amelyet beállított login.php. 48 00:03:18,240 --> 00:03:21,010 Szóval ezt nézd meg a böngészőben. 49 00:03:21,010 --> 00:03:27,520 Először is, akkor keresse meg http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Láthatjuk, hogy itt már nem jelentkezett be még, 51 00:03:30,220 --> 00:03:35,040 úgyhogy kattintson a bejelentkezési hivatkozásra, amely átirányítja minket login.php. 52 00:03:35,040 --> 00:03:41,760 Oké, akkor írja be a nevét, amely ezután tárolja az ülésen. 53 00:03:41,760 --> 00:03:48,950 Nagyszerű! Most már látom a bemeneti login.php on hello.php keresztül ülésén. 54 00:03:48,950 --> 00:03:52,270 Szóval, mi a fakitermelés a felhasználó ki? 55 00:03:52,270 --> 00:03:58,510 Nos, annak érdekében, hogy jelentkezzen be a felhasználó, akkor egyszerűen a tárolt értéket a munkamenet nevét. 56 00:03:58,510 --> 00:04:03,040 Tehát, hogy jelentkezzen be a felhasználó ki, egyszerűen el kell távolítani ezt a nevet kulcsot 57 00:04:03,040 --> 00:04:05,040 A munkamenet tömbben. 58 00:04:05,040 --> 00:04:09,130 Szóval vessünk egy pillantást az utolsó fájl logout.php. 59 00:04:09,130 --> 00:04:12,080 Még egyszer, akkor kell hívni session_start () 60 00:04:12,080 --> 00:04:15,260 mielőtt bármit megtehet munkamenet kapcsolatban. 61 00:04:15,260 --> 00:04:19,240 Most egyszerűen hívja session_destroy (), 62 00:04:19,240 --> 00:04:22,460 amely gondoskodik megszabadulni az összes adatot a munkamenet 63 00:04:22,460 --> 00:04:26,790 majd átirányítja a felhasználót vissza hello.php. 64 00:04:26,790 --> 00:04:30,700 Tehát, ha rákattintok a Kilépés linkre, 65 00:04:30,700 --> 00:04:34,690 láthatjuk, hogy a szerver elfelejtette, hogy ki vagyok, 66 00:04:34,690 --> 00:04:36,970 és én már nem vagy bejelentkezve, 67 00:04:36,970 --> 00:04:39,910 Szóval, mi folyik itt, a motorháztető alatt? 68 00:04:39,910 --> 00:04:42,250 Annak érdekében, hogy a viselkedés láttunk, 69 00:04:42,250 --> 00:04:44,760 szerverünk kell 2 dolog. 70 00:04:44,760 --> 00:04:48,980 Először is, a kiszolgálónak, hogy valamilyen módon tárolja az adatokat az ülésen. 71 00:04:48,980 --> 00:04:51,910 A különböző PHP fájlok tartalmazzák a weboldalon 72 00:04:51,910 --> 00:04:56,500 végrehajtása külön felépíthető a PHP értelmező 73 00:04:56,500 --> 00:05:00,550 így lokális változót nem lehet osztani közöttük. 74 00:05:00,550 --> 00:05:04,030 Ehelyett a kiszolgáló kell tárolni a munkamenet adatokat 75 00:05:04,030 --> 00:05:08,440 néhány helyen, hogy több. php fájlt elérheti. 76 00:05:08,440 --> 00:05:13,940 Másodszor, a szerver kell társítani a munkamenet adatokat csak a böngészés. 77 00:05:13,940 --> 00:05:15,940 Amikor be, hogy a Facebook, 78 00:05:15,940 --> 00:05:20,460 ott valószínűleg több millió más ember is bejelentkezett a Facebook egyszerre. 79 00:05:20,460 --> 00:05:24,200 De a kiszolgálónak valamilyen módon bevonják adataim 80 00:05:24,200 --> 00:05:28,340 a mostani ülésen, és valaki más adatait egy másik ülésen. 81 00:05:28,340 --> 00:05:32,380 Szerencsére, a szerzők a PHP gondoltam mindezt nekünk, 82 00:05:32,380 --> 00:05:35,170 így nem kell hajtotta végre magunk. 83 00:05:35,170 --> 00:05:39,540 De vessünk egy pillantást, amit PHP csinál alapértelmezés szerint. 84 00:05:39,540 --> 00:05:44,070 Amikor meglátogat egy PHP oldal tartalmazza session_start az első alkalommal, 85 00:05:44,070 --> 00:05:47,930 PHP generál egy nagy véletlen érték. 86 00:05:47,930 --> 00:05:53,970 Amíg session_destroy hívják, vagy én ne keresse fel a PHP oldalt, hogy a helyszínen egy ideig- 87 00:05:53,970 --> 00:05:59,050 hogy a véletlenszerű és valószínűleg egyedi érték társul velem. 88 00:05:59,050 --> 00:06:02,780 Így a szerver valamilyen módon azonosítani a böngészési munkamenet 89 00:06:02,780 --> 00:06:05,710 szemben valaki más. 90 00:06:05,710 --> 00:06:08,780 Mi is vessünk egy pillantást az aktuális munkamenet azonosító 91 00:06:08,780 --> 00:06:12,380 a PHP függvény, session_id. 92 00:06:12,380 --> 00:06:17,250 Itt mi csak kimenetre értékét a munkamenet azonosító. 93 00:06:17,250 --> 00:06:20,580 Tehát, ha ismét be a példában web app, 94 00:06:20,580 --> 00:06:25,530 és most keresse meg sessid.php, 95 00:06:25,530 --> 00:06:27,850 majd meglátjuk, ezt a hosszú karaktersorozatot, 96 00:06:27,850 --> 00:06:31,180 és ez a jelenlegi azonosító az edzést, 97 00:06:31,180 --> 00:06:35,410 és ez az, hogy a szerver nyomon követését, hogy ki vagyok. 98 00:06:35,410 --> 00:06:37,670 Oké, de mi már csak megoldani a fele a problémát. 99 00:06:37,670 --> 00:06:40,910 Persze, a szerver most már valamilyen módon azonosítani engem, 100 00:06:40,910 --> 00:06:46,060 de amikor látogasson el egy másik oldalon, a kiszolgálónak, hogy újra, hogy ugyanazt az azonosítót 101 00:06:46,060 --> 00:06:48,910 ahelyett, generál egy újat. 102 00:06:48,910 --> 00:06:52,760 Ne feledje, ha kijelentem, helyi változó foo.php 103 00:06:52,760 --> 00:06:55,190 majd keresse bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php nem lehet tudni, mi történt foo.php. 105 00:07:00,980 --> 00:07:07,450 Így az alapértelmezett PHP munkamenet alkalmazás megköveteli, hogy a böngésző emlékeztesse a szerver 106 00:07:07,450 --> 00:07:09,740 amely session ID használható. 107 00:07:09,740 --> 00:07:12,710 Ennek megvalósítása formájában egy sütit. 108 00:07:12,710 --> 00:07:15,370 A cookie-amellett, hogy a finom uzsonna- 109 00:07:15,370 --> 00:07:18,630 egyszerűen egy kis szöveges fájlt a számítógépen 110 00:07:18,630 --> 00:07:21,780 , amelyet a szerver írni a webböngésző segítségével. 111 00:07:21,780 --> 00:07:27,300 Így aztán PHP generál az egyedi session ID-n keresztül session_start, 112 00:07:27,300 --> 00:07:34,210 ez fogja mondani a böngésző tárolni, hogy azonosító egy szöveges fájl, vagy egy sütit. 113 00:07:34,210 --> 00:07:38,490 Ezután a web böngésző közé tartozik, hogy azonosítót minden kérést 114 00:07:38,490 --> 00:07:40,780 hogy teszi a szerver. 115 00:07:40,780 --> 00:07:44,280 Szóval tényleg, a web szerver nem emlékszik, hogy ki vagyok. 116 00:07:44,280 --> 00:07:48,780 Ehelyett, a böngésző egyszerűen emlékezve az egyedi azonosító 117 00:07:48,780 --> 00:07:52,730 hogy keletkezett a PHP, majd állandóan emlékeztetve a szerver 118 00:07:52,730 --> 00:07:55,120 , mi az azonosító. 119 00:07:55,120 --> 00:08:00,760 Így, információkat, mint a felhasználónév a szerveren tárolódnak nem a böngésző. 120 00:08:00,760 --> 00:08:05,190 A böngésző egyszerűen megmondja a szervernek, ahol a PHP tárolják az információt 121 00:08:05,190 --> 00:08:07,750 így PHP letölthetjük azt. 122 00:08:07,750 --> 00:08:12,150 Ahhoz, hogy felmerül a kérdés, hol van a PHP tényleges tárolja ezt az információt? 123 00:08:12,150 --> 00:08:14,910 Alapértelmezésben a PHP tárolja a session adatokat 124 00:08:14,910 --> 00:08:19,540 egy fájlban belsejében a / tmp, vagy a "temp" mappát. 125 00:08:19,540 --> 00:08:24,450 A fájl neve tartalmazza a session ID, így a PHP tudja határozni 126 00:08:24,450 --> 00:08:28,620 melyik fájlt írni és olvasni a Via csak a session ID. 127 00:08:28,620 --> 00:08:32,280 Rendben van. Szóval megnyitja a Hálózat fülre Chrome debugger 128 00:08:32,280 --> 00:08:34,890 keresztül a csavarkulcs ikonra a jobb felső sarokban. 129 00:08:34,890 --> 00:08:38,409 Most menj a hello.php újra. 130 00:08:38,409 --> 00:08:42,270 Nézzük kattintson a HTTP kérést hello.php 131 00:08:42,270 --> 00:08:44,680 , majd kattintson a fejlécek. 132 00:08:44,680 --> 00:08:50,390 Itt azt látjuk, hogy a cookie-fejléc tartalmaz egy kulcsot nevű PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 vagy PHP session ID-egy értéket, hogy ugyanaz a hosszú sora láttunk 134 00:08:55,980 --> 00:08:59,290 amikor meglátogattuk sessid.php. 135 00:08:59,290 --> 00:09:04,660 Ez pontosan az, hogy a böngésző emlékeztetve a szerver milyen session ID kell használni. 136 00:09:04,660 --> 00:09:08,180 Ez többek között azt egy HTTP fejléc. 137 00:09:08,180 --> 00:09:10,500 Rendben van. Menjünk vissza a terminálhoz. 138 00:09:10,500 --> 00:09:16,450 Nézzük keresse meg a / tmp könyvtárba, ahol a PHP tárolja a session információkat alapértelmezés szerint. 139 00:09:16,450 --> 00:09:19,160 Valóban, belsejében ez ideiglenes mappába, 140 00:09:19,160 --> 00:09:23,550 itt van egy fájl, ami tartalmazza a pontosan ugyanolyan session ID. 141 00:09:23,550 --> 00:09:28,990 Ha megnyitja ezt a fájlt, akkor láthatjuk, hogy a PHP-t képviseli az ülésen a lemezen. 142 00:09:28,990 --> 00:09:32,870 Itt a string "Tommy" van tárolva a kulcs neve, " 143 00:09:32,870 --> 00:09:35,750 ami pontosan az, amit vártunk. 144 00:09:35,750 --> 00:09:38,850 És ez egy áttekintést ülés PHP. 145 00:09:38,850 --> 00:09:42,590 Amit most láttam csak az alapértelmezett végrehajtását ülés. 146 00:09:42,590 --> 00:09:45,600 Tény, hogy sok websites átállítani az alapértelmezett viselkedés 147 00:09:45,600 --> 00:09:48,280 tárolni PHP munkamenetek hatékonyabban 148 00:09:48,280 --> 00:09:50,390 az az érdeke, javítja a teljesítményt. 149 00:09:50,390 --> 00:09:52,800 A nevem Tommy, és ez CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]