1 00:00:00,000 --> 00:00:02,000 [Powered by Google Translate] [PHP Posėdžiai] 2 00:00:02,000 --> 00:00:04,000 [Tommy MacWilliam, Harvardo universitetas] 3 00:00:04,000 --> 00:00:07,000 [Tai CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Sesijos PHP gali būti naudojama įgyvendinti funkcionalumą, 5 00:00:10,920 --> 00:00:13,440 kaip įėjimai, jūsų interneto app. 6 00:00:13,440 --> 00:00:16,920 PHP sesijų leidžia susieti informaciją 7 00:00:16,920 --> 00:00:19,680 su naudotojo visą naršymo sesijos 8 00:00:19,680 --> 00:00:22,290 o ne vien tik į vieną puslapį. 9 00:00:22,290 --> 00:00:27,330 Taigi, tai reiškia, kad, kaip vartotojas apsilanko įvairių PHP puslapius, kurie sudaro jūsų svetainę, 10 00:00:27,330 --> 00:00:30,630 bet koks sesijos informacija išliks. 11 00:00:30,630 --> 00:00:34,770 Taigi, tai reiškia, kad saugomi sesijos vieno puslapio duomenys 12 00:00:34,770 --> 00:00:37,580 vėliau gali būti prieinama kitą puslapį. 13 00:00:37,580 --> 00:00:40,080 Saugoti informaciją sesija yra labai paprasta, 14 00:00:40,080 --> 00:00:48,790 ir mes padaryti per dolerio ženklas, pabrėžti, kapitalo sesijos kintamasis. 15 00:00:48,790 --> 00:00:52,620 Doleris ženklas, pabrėžti, seanso kaip dolerio ženklas, pabrėžti, GAUTI 16 00:00:52,620 --> 00:00:54,710 ir dolerio ženklas, pabrėžti, PO 17 00:00:54,710 --> 00:00:58,690 yra masyvą, sudarytas iš pagrindinių vertės poromis. 18 00:00:58,690 --> 00:01:07,980 Taigi, mes galime naudoti sintaksės panašus dolerio ženklas, pabrėžti, sesijos 19 00:01:07,980 --> 00:01:16,000 laikiklis, citata, foo citata, laikiklis, lygios, citata, baras, citata- 20 00:01:16,000 --> 00:01:20,440 saugoti vertės "kartelę" į rakto "foo". 21 00:01:20,440 --> 00:01:24,030 Tačiau, kol mes galime skaityti iš sesijos masyvo arba rašyti, 22 00:01:24,030 --> 00:01:26,770 mes turime skambinti specialią funkciją- 23 00:01:26,770 --> 00:01:34,690 sesija, pabrėžti, pradėti (), - 24 00:01:34,690 --> 00:01:37,060 ir tai bus inicijuoti seansą. 25 00:01:37,060 --> 00:01:39,850 Taigi galime pažvelgti pavyzdžiui išvaizdą. 26 00:01:39,850 --> 00:01:46,570 Mūsų pirmasis puslapis, hello.php, naudoja sesijos produkcijos kai kuriuos duomenis vartotojui. 27 00:01:46,570 --> 00:01:53,920 Atminkite, kad mes turime naudoti session_start kol mes galime prieiti prie bet kurios sesijos duomenis. 28 00:01:53,920 --> 00:01:59,010 Dabar mes naudojame PHP isset nustatyti, ar raktas egzistuoja 29 00:01:59,010 --> 00:02:03,230 į $ _SESSION masyvą. 30 00:02:03,230 --> 00:02:07,250 Jei tas raktas yra, tai reiškia, kad vartotojas prisijungęs, 31 00:02:07,250 --> 00:02:10,410 todėl rodysime vartotojo vardą. 32 00:02:10,410 --> 00:02:14,110 Jei tai raktas nėra nustatytas, tai reiškia, kad vartotojas dar neprisijungė, 33 00:02:14,110 --> 00:02:17,880 todėl rodysime nuorodą į login.php. 34 00:02:17,880 --> 00:02:21,380 Taigi, galime pažvelgti į login.php išvaizdą. 35 00:02:21,380 --> 00:02:26,260 Žemyn čia, mes turime vieną HTML formą su viena įėjimo. 36 00:02:26,260 --> 00:02:32,720 Formą veiksmai atributas yra $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 ir tai tiesiog reiškia, kad mes norime, forma turi būti pateikta per dabartinę failą, 38 00:02:37,440 --> 00:02:41,040 , kuris šiuo atveju yra login.php. 39 00:02:41,040 --> 00:02:43,010 Taigi, grįžkime prie šio failo viršuje. 40 00:02:43,010 --> 00:02:50,100 Jei naudotojas pateikė formą, tada $ _POST ['vardas'] turi būti nustatytas. 41 00:02:50,100 --> 00:02:53,750 Daugiau informacijos apie HTML formas ir pareigas, 42 00:02:53,750 --> 00:02:56,510 patikrinkite PHP Web Development vaizdo. 43 00:02:56,510 --> 00:02:59,330 Tuo atveju, kai vartotojas padarė pateikti formą, 44 00:02:59,330 --> 00:03:03,970 mes norėtume rašyti vertę, kad jie įvedėte į sesiją. 45 00:03:03,970 --> 00:03:08,540 Dabar mes galime nukreipti vartotoją į hello.php. 46 00:03:08,540 --> 00:03:11,800 Kadangi mes saugomi vartotojo indėlį į sesijos 47 00:03:11,800 --> 00:03:18,240 hello.php galės naudotis vertę, kuri buvo nustatyta per login.php. 48 00:03:18,240 --> 00:03:21,010 Taigi galime tai patikrinti naršyklėje. 49 00:03:21,010 --> 00:03:27,520 Pirma, mes pereiti į http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Mes matome, kad čia mes dar neprisijungė, 51 00:03:30,220 --> 00:03:35,040 tad spustelėkite prisijungimo nuorodą, kuri bus nukreipti mums login.php. 52 00:03:35,040 --> 00:03:41,760 Gerai, aš įvesti savo vardą, kuris bus saugomas sesijos. 53 00:03:41,760 --> 00:03:48,950 Puiku! Dabar mes galime matyti mano pirkimo iš login.php apie hello.php per sesiją. 54 00:03:48,950 --> 00:03:52,270 Taigi, ką apie prisijungti vartotojui iš? 55 00:03:52,270 --> 00:03:58,510 Na, norint prisijungti vartotojui, mes tiesiog laikyti reikšmę į sesijos pavadinimu. 56 00:03:58,510 --> 00:04:03,040 Taigi, norint prisijungti vartotojui iš, mes tiesiog reikia pašalinti tokiu pavadinimu klavišą 57 00:04:03,040 --> 00:04:05,040 nuo sesijos masyvo. 58 00:04:05,040 --> 00:04:09,130 Taigi, galime pažvelgti į šio paskutinio failo išvaizdą, logout.php. 59 00:04:09,130 --> 00:04:12,080 Dar kartą, mes turime skambinti session_start () 60 00:04:12,080 --> 00:04:15,260 kol mes galime padaryti nieko sesiją susijusi. 61 00:04:15,260 --> 00:04:19,240 Dabar mes galime tiesiog paskambinkite session_destroy () 62 00:04:19,240 --> 00:04:22,460 kurios rūpinsis atsikratyti visų sesijos duomenų 63 00:04:22,460 --> 00:04:26,790 ir tada nukreipti vartotoją į hello.php. 64 00:04:26,790 --> 00:04:30,700 Taigi, jei aš spustelėkite Atsijungti nuorodą 65 00:04:30,700 --> 00:04:34,690 matome, kad serveris pamiršta, kas aš esu, 66 00:04:34,690 --> 00:04:36,970 ir aš nebe prisijungęs 67 00:04:36,970 --> 00:04:39,910 Taigi, kas čia vyksta po gaubtu? 68 00:04:39,910 --> 00:04:42,250 Siekiant gauti tokį elgesį mes tiesiog pamačiau, 69 00:04:42,250 --> 00:04:44,760 mūsų serveris reikia padaryti 2 dalykus. 70 00:04:44,760 --> 00:04:48,980 Pirma, serveris turi kažkaip saugoti į sesijos duomenis. 71 00:04:48,980 --> 00:04:51,910 Skirtingos PHP failus, kurie sudaro svetainę 72 00:04:51,910 --> 00:04:56,500 vykdomi kaip atskiri kreipinius į PHP vertėjo 73 00:04:56,500 --> 00:05:00,550 todėl vietos kintamasis negali būti dalijamasi tarp jų. 74 00:05:00,550 --> 00:05:04,030 Vietoj to, kad serveris turi saugoti mūsų panaudos duomenis 75 00:05:04,030 --> 00:05:08,440 kai vieta, kad daug. php failai gali prieiti. 76 00:05:08,440 --> 00:05:13,940 Antra, serveris turi susieti panaudos duomenis tik mano naršymo seansą. 77 00:05:13,940 --> 00:05:15,940 Kai aš prisijungti prie "Facebook", 78 00:05:15,940 --> 00:05:20,460 Tikriausiai yra milijonai kitų žmonių, taip pat prisijungęs prie "Facebook" tuo pačiu metu. 79 00:05:20,460 --> 00:05:24,200 Bet serverį reikia šiek tiek susieti savo duomenis kaip 80 00:05:24,200 --> 00:05:28,340 mano dabartinės sesijos ir kažkieno duomenimis su kitoje sesijoje. 81 00:05:28,340 --> 00:05:32,380 Laimei, PHP autoriai galvojo apie visa tai mums, 82 00:05:32,380 --> 00:05:35,170 todėl nereikia įdiegti bet tai patys. 83 00:05:35,170 --> 00:05:39,540 Tačiau galime pažvelgti, kas PHP veikia pagal nutylėjimą išvaizdą. 84 00:05:39,540 --> 00:05:44,070 Kai grįžtu PHP puslapį, kuriame session_start pirmą kartą, 85 00:05:44,070 --> 00:05:47,930 PHP sukels didelį atsitiktinių vertę. 86 00:05:47,930 --> 00:05:53,970 Iki session_destroy vadinama ar aš ne aplankyti bet PHP toje vietoje tam tikrą laiką, 87 00:05:53,970 --> 00:05:59,050 kad atsitiktinai ir tikriausiai unikalus vertė bus susijęs su manimi. 88 00:05:59,050 --> 00:06:02,780 Tokiu būdu serveris turi galimybę nustatyti savo naršymo seansą būdas 89 00:06:02,780 --> 00:06:05,710 , o ne kažkieno. 90 00:06:05,710 --> 00:06:08,780 Galime pažvelgti į dabartinės sesijos ID išvaizdą 91 00:06:08,780 --> 00:06:12,380 naudojant PHP funkciją, session_id. 92 00:06:12,380 --> 00:06:17,250 Čia mes tiesiog išvedė mūsų sesijos identifikatorių vertę. 93 00:06:17,250 --> 00:06:20,580 Taigi, jei mes vėl prisijungti prie pvz. interneto app, 94 00:06:20,580 --> 00:06:25,530 o dabar pereiti į sessid.php, 95 00:06:25,530 --> 00:06:27,850 matysime šį ilgą eilutę simbolių, 96 00:06:27,850 --> 00:06:31,180 ir kad dabartinė identifikatorius mano sesijos 97 00:06:31,180 --> 00:06:35,410 ir tai, kaip serveris yra sekti, kas aš esu. 98 00:06:35,410 --> 00:06:37,670 Gerai, bet mes tik išspręsta pusė problemos. 99 00:06:37,670 --> 00:06:40,910 Žinoma, serveris dabar turi galimybę nustatyti man kelią, 100 00:06:40,910 --> 00:06:46,060 bet kai aš aplankyti kitą puslapį, serverį, reikia pakartotinai tą patį identifikatorių 101 00:06:46,060 --> 00:06:48,910 o ne sukurti naują. 102 00:06:48,910 --> 00:06:52,760 Atminkite, kad jei aš pareiškiu, vietos kintamąjį foo.php 103 00:06:52,760 --> 00:06:55,190 ir tada eikite bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php neturi žinoti, kas atsitiko foo.php kelią. 105 00:07:00,980 --> 00:07:07,450 Taigi, pagal nutylėjimą PHP sesijos įgyvendinimas reikalauja, kad naršyklė priminti serverį 106 00:07:07,450 --> 00:07:09,740 kurios sesijos ID naudoti. 107 00:07:09,740 --> 00:07:12,710 Tai įgyvendinta slapuko forma. 108 00:07:12,710 --> 00:07:15,370 Slapukas yra ne tik skanus užkandis- 109 00:07:15,370 --> 00:07:18,630 yra tiesiog mažas tekstinis failas jūsų kompiuteryje 110 00:07:18,630 --> 00:07:21,780 kad serveris gali rašyti per naršyklę. 111 00:07:21,780 --> 00:07:27,300 Taigi po PHP sukuria savo unikalų sesijos ID per session_start, 112 00:07:27,300 --> 00:07:34,210 jis ketina pasakyti naršyklę saugoti tą identifikatorių vietos tekstinį failą, ar sausainis. 113 00:07:34,210 --> 00:07:38,490 Tada naršyklė bus įtraukti tą identifikatorių kiekvieną prašymą 114 00:07:38,490 --> 00:07:40,780 kad ji daro į serverį. 115 00:07:40,780 --> 00:07:44,280 Taigi tikrai, žiniatinklio serveris yra ne prisiminti, kas aš esu. 116 00:07:44,280 --> 00:07:48,780 Vietoj to, interneto naršyklė tiesiog prisiminti unikalus identifikatorius 117 00:07:48,780 --> 00:07:52,730 , kuris buvo sukurtas naudojant PHP ir tada nuolat priminti serverį 118 00:07:52,730 --> 00:07:55,120 kas, kad identifikatorius. 119 00:07:55,120 --> 00:08:00,760 Tokiu būdu, informacija kaip mano vartotojo vardą, yra saugomi serveryje ne mano interneto naršyklėje. 120 00:08:00,760 --> 00:08:05,190 Naršyklė tiesiog pasakoja serveryje, kur PHP saugomi, kad informacija 121 00:08:05,190 --> 00:08:07,750 taip PHP gali gauti. 122 00:08:07,750 --> 00:08:12,150 Taigi, kad kyla klausimas, kur yra PHP tikrųjų būtų saugoma šią informaciją? 123 00:08:12,150 --> 00:08:14,910 Pagal nutylėjimą, PHP bus laikyti savo sesijos duomenis 124 00:08:14,910 --> 00:08:19,540 į vidinį iš / tmp, arba "Temp" kataloge failą. 125 00:08:19,540 --> 00:08:24,450 Šio failo vardas bus sesijos ID, kad PHP gali nustatyti 126 00:08:24,450 --> 00:08:28,620 kuris failas skaityti ir rašyti nuo per tik sesijos ID. 127 00:08:28,620 --> 00:08:32,280 Gerai. Taigi galime atverti tinklo skirtuką Chrome "debugger 128 00:08:32,280 --> 00:08:34,890 per veržliarakčio piktogramą viršutiniame dešiniajame kampe. 129 00:08:34,890 --> 00:08:38,409 Dabar tegul galva hello.php dar kartą. 130 00:08:38,409 --> 00:08:42,270 Leiskite paspauskite ant HTTP užklausa į hello.php 131 00:08:42,270 --> 00:08:44,680 ir tada spustelėkite antraštes. 132 00:08:44,680 --> 00:08:50,390 Čia mes matome, kad slapukas antraštėje yra raktas vadinamas PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 arba PHP sesijos ID, kurio reikšmė yra ta pati ilgą eilutę mes matėme 134 00:08:55,980 --> 00:08:59,290 kai lankėmės sessid.php. 135 00:08:59,290 --> 00:09:04,660 Tai yra būtent tai, kaip naršyklė primenanti serverį ir sesijos ID turi būti naudojamas. 136 00:09:04,660 --> 00:09:08,180 Tai įskaitant jį į HTTP antraštę. 137 00:09:08,180 --> 00:09:10,500 Gerai. Leiskite grįžkite į terminalą. 138 00:09:10,500 --> 00:09:16,450 Leiskite pereiti į / tmp, kur PHP saugoti informaciją panaudos pagal nutylėjimą. 139 00:09:16,450 --> 00:09:19,160 Be abejo, viduje šį laikinąjį aplanką, 140 00:09:19,160 --> 00:09:23,550 čia failas, kuriame pats tiksliai sesijos ID. 141 00:09:23,550 --> 00:09:28,990 Jei mes atverti šį failą, mes galime pamatyti, kaip PHP, atstovaujanti savo session diską. 142 00:09:28,990 --> 00:09:32,870 Čia eilutė "Tommy" yra laikomas pagrindine "pavadinimas" 143 00:09:32,870 --> 00:09:35,750 kuri yra būtent tai, ko mes tikėjomės. 144 00:09:35,750 --> 00:09:38,850 Ir tai sesijų PHP apžvalga. 145 00:09:38,850 --> 00:09:42,590 Ką mes tiesiog pamačiau, buvo tik numatytasis įgyvendinimas sesijų. 146 00:09:42,590 --> 00:09:45,600 Tiesą sakant, daugelis svetainių, pakeisti šią numatytąją elgseną 147 00:09:45,600 --> 00:09:48,280 efektyviau saugoti PHP sesijas 148 00:09:48,280 --> 00:09:50,390 siekiant pagerinti našumą interesus. 149 00:09:50,390 --> 00:09:52,800 Mano vardas Tomas, o tai CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]