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 [See on CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Sessions PHP saab rakendada funktsionaalsuse 5 00:00:10,920 --> 00:00:13,440 nagu kasutaja sisselogimise, veebi app. 6 00:00:13,440 --> 00:00:16,920 PHP istungid võimaldavad teil seostada teave 7 00:00:16,920 --> 00:00:19,680 koos kasutaja kogu sirvimisseansil 8 00:00:19,680 --> 00:00:22,290 mitte lihtsalt ühel leheküljel. 9 00:00:22,290 --> 00:00:27,330 See tähendab, kui kasutaja külastab erinevaid PHP lehekülgi, mis moodustavad oma veebilehel, 10 00:00:27,330 --> 00:00:30,630 tahes teabe istungil jätkuvad. 11 00:00:30,630 --> 00:00:34,770 See tähendab, et andmed salvestatakse sessiooni ühel lehel 12 00:00:34,770 --> 00:00:37,580 saab hiljem juurde teisele lehele. 13 00:00:37,580 --> 00:00:40,080 Teabe säilitamise istung on lihtne, 14 00:00:40,080 --> 00:00:48,790 ja me teeme seda läbi dollari märk, rõhutavad, kapitali SESSION muutuja. 15 00:00:48,790 --> 00:00:52,620 Dollar märk, rõhutavad, SESSION-nagu dollari märk, rõhutavad, GET 16 00:00:52,620 --> 00:00:54,710 ja dollari märk, rõhutavad, post- 17 00:00:54,710 --> 00:00:58,690 on assotsiatiivne massiiv koosneb põhiväärtus paari. 18 00:00:58,690 --> 00:01:07,980 Nii saame kasutada süntaksi nagu dollari märk, rõhutavad, sessiooni 19 00:01:07,980 --> 00:01:16,000 sulg, quote, foo, quote, sulg, võrdne quote, baar, quote- 20 00:01:16,000 --> 00:01:20,440 Väärtuse salvestamiseks "bar" võti "foo". 21 00:01:20,440 --> 00:01:24,030 Kuid enne, kui me saame kirjutada või lugeda sessiooni massiivi 22 00:01:24,030 --> 00:01:26,770 me vajame helistada lisafunktsiooni- 23 00:01:26,770 --> 00:01:34,690 istungil rõhutada, start () - 24 00:01:34,690 --> 00:01:37,060 ja see initsialiseerida istungil. 25 00:01:37,060 --> 00:01:39,850 Võtame pilk näiteks. 26 00:01:39,850 --> 00:01:46,570 Meie esimesel leheküljel, hello.php kasutab seansi väljund mõned andmed kasutajale. 27 00:01:46,570 --> 00:01:53,920 Pea meeles, et me peame kasutama session_start enne suudame iga sessioon andmed. 28 00:01:53,920 --> 00:01:59,010 Nüüd me kasutame PHP isset teha kindlaks, kas võti on olemas 29 00:01:59,010 --> 00:02:03,230 aastal $ _SESSION assotsiatiivne massiiv. 30 00:02:03,230 --> 00:02:07,250 Kui see võti on olemas, mis tähendab, et kasutaja on sisse logitud, 31 00:02:07,250 --> 00:02:10,410 nii näitame kasutaja nimi. 32 00:02:10,410 --> 00:02:14,110 Kui seda võtit ei ole valitud, mis tähendab, et kasutaja ei ole sisse loginud veel 33 00:02:14,110 --> 00:02:17,880 nii näitame lingi login.php. 34 00:02:17,880 --> 00:02:21,380 Võtame pilk login.php. 35 00:02:21,380 --> 00:02:26,260 Siia, meil on ühe HTML kujul ühe sisend. 36 00:02:26,260 --> 00:02:32,720 Vormi tegevuse atribuut on $ _SERVER ['PHP_SELF "] 37 00:02:32,720 --> 00:02:37,440 ja see tähendab lihtsalt seda, et me tahame, et vorm tuleb esitada jooksva faili 38 00:02:37,440 --> 00:02:41,040 mis antud juhul on login.php. 39 00:02:41,040 --> 00:02:43,010 Lähme tagasi üles selle faili. 40 00:02:43,010 --> 00:02:50,100 Kui kasutaja esitatud kujul, siis $ _POST ['nimi'] tuleb kehtestada. 41 00:02:50,100 --> 00:02:53,750 Lisateavet HTML vormide ja post, 42 00:02:53,750 --> 00:02:56,510 kontrollige PHP Web Development video. 43 00:02:56,510 --> 00:02:59,330 Juhul, kui kasutaja ei sisesta vorm, 44 00:02:59,330 --> 00:03:03,970 me tahaks kirjutada väärtus, et nad kirjutasid sisse istungil. 45 00:03:03,970 --> 00:03:08,540 Nüüd saame suunata kasutaja hello.php. 46 00:03:08,540 --> 00:03:11,800 Kuna meil salvestatud kasutaja sisestada istungil 47 00:03:11,800 --> 00:03:18,240 hello.php ei pääse väärtus, mis oli seatud login.php. 48 00:03:18,240 --> 00:03:21,010 Nii vaatame selle läbi veebibrauseri. 49 00:03:21,010 --> 00:03:27,520 Esiteks, me navigeerida http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Me näeme siin, et me pole veel sisse loginud, 51 00:03:30,220 --> 00:03:35,040 niiet kliki login link, mis suunab meid login.php. 52 00:03:35,040 --> 00:03:41,760 Olgu, ma kirjuta oma nimi, mis seejärel salvestatakse sessiooni. 53 00:03:41,760 --> 00:03:48,950 Suurepärane! Nüüd näeme oma panuse login.php on hello.php kaudu istungil. 54 00:03:48,950 --> 00:03:52,270 Niisiis, kuidas logib kasutaja välja? 55 00:03:52,270 --> 00:03:58,510 Noh, et logida kasutaja, me lihtsalt salvestatud väärtuse seansi nime. 56 00:03:58,510 --> 00:04:03,040 Nii logida kasutaja välja, me lihtsalt vaja eemaldada, et nimi võti 57 00:04:03,040 --> 00:04:05,040 alates sessiooni massiivi. 58 00:04:05,040 --> 00:04:09,130 Võtame pilk see viimane fail, logout.php. 59 00:04:09,130 --> 00:04:12,080 Veelkord, me vajame helistada session_start () 60 00:04:12,080 --> 00:04:15,260 enne, kui me ei saa midagi teha sessiooni seotud. 61 00:04:15,260 --> 00:04:19,240 Nüüd me lihtsalt helistada session_destroy () 62 00:04:19,240 --> 00:04:22,460 mis hoolitseb vabanemiseks kõik andmed istung 63 00:04:22,460 --> 00:04:26,790 ja siis suunata kasutaja tagasi hello.php. 64 00:04:26,790 --> 00:04:30,700 Nii et kui ma klõpsa Logi välja linki 65 00:04:30,700 --> 00:04:34,690 näeme, et server on unustanud, kes ma olen, 66 00:04:34,690 --> 00:04:36,970 ja ma ei ole enam sisse logitud 67 00:04:36,970 --> 00:04:39,910 Mis siis siin toimub all kapuuts? 68 00:04:39,910 --> 00:04:42,250 Selleks, et saada käitumist me nägime, 69 00:04:42,250 --> 00:04:44,760 Meie server peab tegema 2 asja. 70 00:04:44,760 --> 00:04:48,980 Esiteks server vajab kuidagi talletada andmeid sessiooni. 71 00:04:48,980 --> 00:04:51,910 Erinevad PHP faile, mis moodustavad veebilehel 72 00:04:51,910 --> 00:04:56,500 teostatakse eraldi invocations PHP tõlk 73 00:04:56,500 --> 00:05:00,550 nii kohaliku muutuja ei saa jagada nende vahel. 74 00:05:00,550 --> 00:05:04,030 Selle asemel, server vajab säilitada meie seansiandmed 75 00:05:04,030 --> 00:05:08,440 mõnes kohas, et mitu. php faile pääseb. 76 00:05:08,440 --> 00:05:13,940 Teiseks, server vajab siduda sessiooni andmeid ainult minu Interneti-seansi. 77 00:05:13,940 --> 00:05:15,940 Kui ma sisse logida Facebook, 78 00:05:15,940 --> 00:05:20,460 tõenäoliselt on olemas miljoneid teisi inimesi ka sisse loginud Facebook samal ajal. 79 00:05:20,460 --> 00:05:24,200 Aga server vajab kuidagi seostada minu andmed 80 00:05:24,200 --> 00:05:28,340 minu praegune seanss ja kellegi andmed teise istungjärgu. 81 00:05:28,340 --> 00:05:32,380 Õnneks autorid PHP mõelnud kõike seda meile, 82 00:05:32,380 --> 00:05:35,170 nii et me ei vaja rakendada seda ise. 83 00:05:35,170 --> 00:05:39,540 Aga võtame pilk PHP teeb vaikimisi. 84 00:05:39,540 --> 00:05:44,070 Kui ma külastan PHP leht, mis sisaldab session_start esmakordselt, 85 00:05:44,070 --> 00:05:47,930 PHP genereerib suure juhuslik väärtus. 86 00:05:47,930 --> 00:05:53,970 Kuni session_destroy nimetatakse-või ma ei külasta iga PHP selle saidi lehekülgede jaoks while- 87 00:05:53,970 --> 00:05:59,050 et juhuslik ja ilmselt ainulaadne väärtus on seotud minuga. 88 00:05:59,050 --> 00:06:02,780 Nii server on mõned välja selgitada minu sirvimisseansil 89 00:06:02,780 --> 00:06:05,710 mitte kellegi teise. 90 00:06:05,710 --> 00:06:08,780 Me ei saa võtta pilk praeguse seansi ID 91 00:06:08,780 --> 00:06:12,380 kasutades PHP funktsioon, session_id. 92 00:06:12,380 --> 00:06:17,250 Siin me lihtsalt kirjutamine väärtus meie sessiooni identifikaator. 93 00:06:17,250 --> 00:06:20,580 Nii et kui me uuesti sisse logida näiteks web app, 94 00:06:20,580 --> 00:06:25,530 ja nüüd navigeerida sessid.php, 95 00:06:25,530 --> 00:06:27,850 me näeme selle pika märgijada, 96 00:06:27,850 --> 00:06:31,180 ja see on praeguse tunnus minu istungil 97 00:06:31,180 --> 00:06:35,410 ja see on, kuidas server on jälgida, kes ma olen. 98 00:06:35,410 --> 00:06:37,670 Okei, aga me oleme alles lahendatud pool probleem. 99 00:06:37,670 --> 00:06:40,910 Muidugi, server on nüüd mingi viis kindlaks mina, 100 00:06:40,910 --> 00:06:46,060 aga kui ma külastada teisele lehele, server vajab uuesti kasutada sama tunnuse 101 00:06:46,060 --> 00:06:48,910 mitte tekitama uusi. 102 00:06:48,910 --> 00:06:52,760 Pea meeles, kui ma tunnistada kohaliku muutuja foo.php 103 00:06:52,760 --> 00:06:55,190 ja siis külastage bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php on kuidagi võimalik teada, mis juhtus foo.php. 105 00:07:00,980 --> 00:07:07,450 Nii vaikimisi PHP sessiooni rakendamine nõuab, et brauser meelde server 106 00:07:07,450 --> 00:07:09,740 mis sessiooni ID kasutamiseks. 107 00:07:09,740 --> 00:07:12,710 Seda rakendatakse kujul küpsis. 108 00:07:12,710 --> 00:07:15,370 Cookie-lisaks on maitsev suupiste- 109 00:07:15,370 --> 00:07:18,630 on lihtsalt väike tekstifail arvutis 110 00:07:18,630 --> 00:07:21,780 et server saab kirjutada kaudu veebibrauser. 111 00:07:21,780 --> 00:07:27,300 Nii et pärast PHP genereerib minu unikaalne sessiooni ID kaudu session_start, 112 00:07:27,300 --> 00:07:34,210 see läheb ütlema veebilehitseja salvestada et tunnus kohalikul tekstifaili või küpsise. 113 00:07:34,210 --> 00:07:38,490 Siis veebilehitseja lisab, et tunnus iga taotluse 114 00:07:38,490 --> 00:07:40,780 et see annab server. 115 00:07:40,780 --> 00:07:44,280 Nii et tõesti, veebiserver ei mäleta, kes ma olen. 116 00:07:44,280 --> 00:07:48,780 Selle asemel, veebibrauser lihtsalt mäleta kordumatu tunnus 117 00:07:48,780 --> 00:07:52,730 , mis oli loodud PHP ja siis pidevalt meelde tuletada server 118 00:07:52,730 --> 00:07:55,120 mida see tunnus on. 119 00:07:55,120 --> 00:08:00,760 Nii informatsiooni nagu minu kasutaja nimi on salvestatud server pole minu veebibrauser. 120 00:08:00,760 --> 00:08:05,190 Brauser lihtsalt ütleb server, kus PHP säilitatakse seda teavet 121 00:08:05,190 --> 00:08:07,750 nii PHP saab taastada. 122 00:08:07,750 --> 00:08:12,150 Nii et tekib küsimus, kus on PHP, salvestades selle artikli eest? 123 00:08:12,150 --> 00:08:14,910 Vaikimisi PHP salvestada istungil andmed 124 00:08:14,910 --> 00:08:19,540 faili sees / tmp või "temp" kausta. 125 00:08:19,540 --> 00:08:24,450 Selle faili nimi sisaldab sessiooni ID nii PHP saab kindlaks 126 00:08:24,450 --> 00:08:28,620 mis faili lugeda ja kirjutada kaudu ainult sessiooni ID. 127 00:08:28,620 --> 00:08:32,280 Hea küll. Nii avame Network sakk Chrome'i siluri 128 00:08:32,280 --> 00:08:34,890 via mutrivõtme ikoon ülemises paremas. 129 00:08:34,890 --> 00:08:38,409 Nüüd pea hello.php uuesti. 130 00:08:38,409 --> 00:08:42,270 Olgem kliki HTTP taotluse hello.php 131 00:08:42,270 --> 00:08:44,680 ja siis klõpsa päised. 132 00:08:44,680 --> 00:08:50,390 Siin näeme, et cookie päises on võti nimega PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 või PHP sessiooni ID-väärtusega, mis on sama pikk string nägime 134 00:08:55,980 --> 00:08:59,290 kui käisime sessid.php. 135 00:08:59,290 --> 00:09:04,660 See on täpselt, kuidas brauser meenutas server mida seansi ID tuleks kasutada. 136 00:09:04,660 --> 00:09:08,180 See on ka see HTTP päises. 137 00:09:08,180 --> 00:09:10,500 Hea küll. Olgem pea tagasi terminali. 138 00:09:10,500 --> 00:09:16,450 Olgem navigeerida / tmp, kus PHP on hoidmiseks sessiooni informatsioon vaikimisi. 139 00:09:16,450 --> 00:09:19,160 Muidugi piisavalt, sees see ajutine kaust, 140 00:09:19,160 --> 00:09:23,550 siin on fail, mis sisaldab täpselt sama sessiooni ID. 141 00:09:23,550 --> 00:09:28,990 Kui me avada see fail, saame näha, kuidas PHP esindab minu istungil disk. 142 00:09:28,990 --> 00:09:32,870 Siin string "Tommy" on salvestatud võtme nimi " 143 00:09:32,870 --> 00:09:35,750 mis on täpselt see, mida me ootasime. 144 00:09:35,750 --> 00:09:38,850 Ja see ülevaade seansse PHP. 145 00:09:38,850 --> 00:09:42,590 Mida me nägime oli ainult default rakendamise istungid. 146 00:09:42,590 --> 00:09:45,600 Tegelikult paljud veebilehed muuta vaikimisi 147 00:09:45,600 --> 00:09:48,280 salvestada PHP istungid tõhusamalt 148 00:09:48,280 --> 00:09:50,390 huvides parandada jõudlust. 149 00:09:50,390 --> 00:09:52,800 Minu nimi on Tommy, ja see on CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]