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 [Dette er CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Økter i PHP kan brukes til å implementere funksjonalitet, 5 00:00:10,920 --> 00:00:13,440 som brukerpålogginger, i din web-app. 6 00:00:13,440 --> 00:00:16,920 PHP økter tillate deg å knytte informasjon 7 00:00:16,920 --> 00:00:19,680 med brukeren hele leseøkt 8 00:00:19,680 --> 00:00:22,290 snarere enn bare en enkelt side. 9 00:00:22,290 --> 00:00:27,330 Så det betyr som brukeren besøker ulike PHP sider som utgjør nettstedet ditt, 10 00:00:27,330 --> 00:00:30,630 all informasjon i økten vil vedvare. 11 00:00:30,630 --> 00:00:34,770 Så det betyr at data som er lagret i økten ved én side 12 00:00:34,770 --> 00:00:37,580 kan senere bli tilgjengelig ved en annen side. 13 00:00:37,580 --> 00:00:40,080 Lagring av informasjon i en økt er lett, 14 00:00:40,080 --> 00:00:48,790 og vi gjør det via dollartegn, understrek, hovedstaden SESSION variabel. 15 00:00:48,790 --> 00:00:52,620 Dollartegn, understrek, SESSION-akkurat som dollartegn, understrek, GET 16 00:00:52,620 --> 00:00:54,710 og dollartegn, understrek, POST- 17 00:00:54,710 --> 00:00:58,690 er en assosiativ array bestående av sentrale verdi-par. 18 00:00:58,690 --> 00:01:07,980 Så vi kan bruke syntaks-lignende dollartegn, understrek, SESSION, 19 00:01:07,980 --> 00:01:16,000 brakett, sitat, foo, sitat, brakett, lik, sitat, bar, sitat- 20 00:01:16,000 --> 00:01:20,440 for å lagre verdien "bar" i nøkkelen "foo". 21 00:01:20,440 --> 00:01:24,030 Men før vi kan skrive eller lese fra økten array, 22 00:01:24,030 --> 00:01:26,770 vi må kalle en spesiell funksjon- 23 00:01:26,770 --> 00:01:34,690 sesjon, understrek, start, () - 24 00:01:34,690 --> 00:01:37,060 og dette vil initial økten. 25 00:01:37,060 --> 00:01:39,850 Så la oss ta en titt på et eksempel. 26 00:01:39,850 --> 00:01:46,570 Vår første side, hello.php, bruker session for å sende ut noen data til brukeren. 27 00:01:46,570 --> 00:01:53,920 Husk, vi må bruke session_start før vi får tilgang til noen sesjonsdata. 28 00:01:53,920 --> 00:01:59,010 Nå bruker vi PHP isset å avgjøre om en nøkkel eksisterer 29 00:01:59,010 --> 00:02:03,230 i $ _SESSION assosiativ array. 30 00:02:03,230 --> 00:02:07,250 Hvis denne nøkkelen finnes, betyr at brukeren har logget inn, 31 00:02:07,250 --> 00:02:10,410 så vi vil vise brukerens navn. 32 00:02:10,410 --> 00:02:14,110 Hvis denne nøkkelen ikke er satt, betyr at brukeren ikke har logget inn enda, 33 00:02:14,110 --> 00:02:17,880 så vi vil vise en kobling til login.php. 34 00:02:17,880 --> 00:02:21,380 Så la oss ta en titt på login.php. 35 00:02:21,380 --> 00:02:26,260 Her nede, har vi et enkelt HTML-skjema med en enkel inngang. 36 00:02:26,260 --> 00:02:32,720 Skjemaets handling attributt er $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 og dette betyr bare at vi vil at skjemaet skal sendes til den aktuelle filen, 38 00:02:37,440 --> 00:02:41,040 som i dette tilfellet, er login.php. 39 00:02:41,040 --> 00:02:43,010 Så la oss gå tilbake til toppen av denne filen. 40 00:02:43,010 --> 00:02:50,100 Hvis brukeren sendt inn skjemaet, deretter $ _POST ['name'] må angis. 41 00:02:50,100 --> 00:02:53,750 For mer informasjon om HTML-skjemaer og innlegg, 42 00:02:53,750 --> 00:02:56,510 sjekk ut PHP Web Development video. 43 00:02:56,510 --> 00:02:59,330 I tilfelle at brukeren gjorde sende inn skjemaet, 44 00:02:59,330 --> 00:03:03,970 vi ønsker å skrive den verdien som de skrev i inn i økten. 45 00:03:03,970 --> 00:03:08,540 Nå kan vi omdirigere brukeren til hello.php. 46 00:03:08,540 --> 00:03:11,800 Fordi vi har lagret på brukerens input inn i økten, 47 00:03:11,800 --> 00:03:18,240 hello.php vil kunne få tilgang til den verdien som ble satt i login.php. 48 00:03:18,240 --> 00:03:21,010 Så la oss sjekke dette ut i en nettleser. 49 00:03:21,010 --> 00:03:27,520 Først vil vi gå til http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Vi ser her at vi ikke har logget inn enda, 51 00:03:30,220 --> 00:03:35,040 så la oss klikke påloggingsadresse, noe som vil omadressere oss til login.php. 52 00:03:35,040 --> 00:03:41,760 Ok, jeg skal skrive om i mitt navn, som deretter vil bli lagret i økten. 53 00:03:41,760 --> 00:03:48,950 Flott! Nå kan vi se mitt innspill fra login.php på hello.php via økten. 54 00:03:48,950 --> 00:03:52,270 Så, hva om logger brukeren ut? 55 00:03:52,270 --> 00:03:58,510 Vel, for å logge brukeren i, vi bare lagret en verdi i session navn. 56 00:03:58,510 --> 00:04:03,040 Så for å logge brukeren ut, må vi rett og slett å fjerne det navnet nøkkelen 57 00:04:03,040 --> 00:04:05,040 fra økten array. 58 00:04:05,040 --> 00:04:09,130 Så la oss ta en titt på denne siste filen, logout.php. 59 00:04:09,130 --> 00:04:12,080 Igjen, vi må ringe session_start () 60 00:04:12,080 --> 00:04:15,260 før vi kan gjøre noe session relatert. 61 00:04:15,260 --> 00:04:19,240 Nå kan vi bare ringe session_destroy (), 62 00:04:19,240 --> 00:04:22,460 som vil ta vare på å kvitte seg med alle data i økten 63 00:04:22,460 --> 00:04:26,790 og deretter omdirigere brukeren tilbake til hello.php. 64 00:04:26,790 --> 00:04:30,700 Så hvis jeg klikker på Logg ut linken, 65 00:04:30,700 --> 00:04:34,690 Vi kan se at serveren har glemt hvem jeg er, 66 00:04:34,690 --> 00:04:36,970 og jeg er ikke lenger logget inn 67 00:04:36,970 --> 00:04:39,910 Så hva er det som skjer her under panseret? 68 00:04:39,910 --> 00:04:42,250 For å få virkemåten vi nettopp så, 69 00:04:42,250 --> 00:04:44,760 vår server trenger å gjøre to ting. 70 00:04:44,760 --> 00:04:48,980 Først må tjeneren liksom lagre dataene i økten. 71 00:04:48,980 --> 00:04:51,910 De ulike PHP-filer som utgjør et nettsted 72 00:04:51,910 --> 00:04:56,500 utføres som egne besvergelser av PHP-tolken 73 00:04:56,500 --> 00:05:00,550 så lokal variabel kan ikke deles mellom dem. 74 00:05:00,550 --> 00:05:04,030 I stedet må serveren til å lagre våre sesjonsdata 75 00:05:04,030 --> 00:05:08,440 i noen sted som flere. php-filer kan få tilgang til. 76 00:05:08,440 --> 00:05:13,940 For det andre må tjeneren knytte data om din økt med bare min surfeøkt. 77 00:05:13,940 --> 00:05:15,940 Når jeg logge inn på Facebook, 78 00:05:15,940 --> 00:05:20,460 det er sannsynligvis millioner av andre mennesker også logget inn på Facebook på samme tid. 79 00:05:20,460 --> 00:05:24,200 Men serveren trenger noen måte å knytte mine data 80 00:05:24,200 --> 00:05:28,340 med min nåværende sesjon og andres data med en annen økt. 81 00:05:28,340 --> 00:05:32,380 Heldigvis, forfatterne av PHP tenkt på alt dette for oss, 82 00:05:32,380 --> 00:05:35,170 slik at vi ikke trenger å gjennomføre noe av dette selv. 83 00:05:35,170 --> 00:05:39,540 Men la oss ta en titt på hva PHP gjør som standard. 84 00:05:39,540 --> 00:05:44,070 Når jeg besøker en PHP side som inneholder session_start for første gang, 85 00:05:44,070 --> 00:05:47,930 PHP vil generere et stort tilfeldig verdi. 86 00:05:47,930 --> 00:05:53,970 Inntil session_destroy kalles-eller jeg vet ikke besøke noen PHP-sider på nettstedet for en stund- 87 00:05:53,970 --> 00:05:59,050 som tilfeldig og sannsynligvis unike verdien vil bli assosiert med meg. 88 00:05:59,050 --> 00:06:02,780 På den måten serveren har noen måte å identifisere min leseøkt 89 00:06:02,780 --> 00:06:05,710 i motsetning til andres. 90 00:06:05,710 --> 00:06:08,780 Vi kan ta en titt på dagens session-ID 91 00:06:08,780 --> 00:06:12,380 ved hjelp av PHP-funksjonen, session_ID. 92 00:06:12,380 --> 00:06:17,250 Her er vi rett og slett gi ut verdien av vår sesjonsidentifikasjon. 93 00:06:17,250 --> 00:06:20,580 Så hvis vi igjen login til eksemplet web app, 94 00:06:20,580 --> 00:06:25,530 og nå navigere til sessid.php, 95 00:06:25,530 --> 00:06:27,850 vi får se dette lang streng av tegn, 96 00:06:27,850 --> 00:06:31,180 og det er den nåværende identifikator for min sesjon, 97 00:06:31,180 --> 00:06:35,410 og det er hvordan serveren er å holde styr på hvem jeg er. 98 00:06:35,410 --> 00:06:37,670 Ok, men vi har bare løst halve problemet. 99 00:06:37,670 --> 00:06:40,910 Jada, nå har serveren noen måte å identifisere meg, 100 00:06:40,910 --> 00:06:46,060 men når jeg besøker en annen side, må tjeneren gjenbruke det samme identifikator 101 00:06:46,060 --> 00:06:48,910 i stedet for å generere en ny. 102 00:06:48,910 --> 00:06:52,760 Husk, hvis jeg erklære en lokal variabel i foo.php 103 00:06:52,760 --> 00:06:55,190 og deretter besøke bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php har ingen måte å vite hva som skjedde i foo.php. 105 00:07:00,980 --> 00:07:07,450 Så standard php session implementering krever at nettleseren minne på serveren 106 00:07:07,450 --> 00:07:09,740 som session-ID for å bruke. 107 00:07:09,740 --> 00:07:12,710 Dette er implementert i form av en informasjonskapsel. 108 00:07:12,710 --> 00:07:15,370 En cookie-i tillegg til å være en deilig snack- 109 00:07:15,370 --> 00:07:18,630 er rett og slett en liten tekstfil på datamaskinen 110 00:07:18,630 --> 00:07:21,780 at en server kan skrive til via nettleseren. 111 00:07:21,780 --> 00:07:27,300 Så etter PHP genererer min unik session ID via session_start, 112 00:07:27,300 --> 00:07:34,210 det kommer til å fortelle nettleseren for å lagre som identifikator i en lokal tekstfil, eller en cookie. 113 00:07:34,210 --> 00:07:38,490 Deretter nettleseren vil inneholde denne identifikatoren i hver forespørsel 114 00:07:38,490 --> 00:07:40,780 at det gjør til serveren. 115 00:07:40,780 --> 00:07:44,280 Så egentlig, er det web server ikke huske hvem jeg er. 116 00:07:44,280 --> 00:07:48,780 I stedet er den nettleseren bare huske den unike identifikator 117 00:07:48,780 --> 00:07:52,730 som ble generert av PHP og deretter stadig minner serveren 118 00:07:52,730 --> 00:07:55,120 hva som identifikator er. 119 00:07:55,120 --> 00:08:00,760 På den måten, informasjon som brukernavnet mitt er lagret på serveren ikke min nettleser. 120 00:08:00,760 --> 00:08:05,190 Nettleseren bare forteller serveren der PHP lagret denne informasjonen 121 00:08:05,190 --> 00:08:07,750 så PHP kan hente det. 122 00:08:07,750 --> 00:08:12,150 Så det ber spørsmålet, hvor er PHP faktisk lagrer denne informasjonen? 123 00:08:12,150 --> 00:08:14,910 Som standard, vil PHP lagre økten data 124 00:08:14,910 --> 00:08:19,540 i en fil inne av / tmp, eller 'temp-mappen. 125 00:08:19,540 --> 00:08:24,450 Navnet på denne filen vil inneholde økten ID så PHP kan avgjøre 126 00:08:24,450 --> 00:08:28,620 hvilken fil for å lese og skrive fra via kun økten ID. 127 00:08:28,620 --> 00:08:32,280 OK. Så la oss åpne opp kategorien Nettverk i Chrome debugger 128 00:08:32,280 --> 00:08:34,890 via skrunøkkel-ikonet øverst til høyre. 129 00:08:34,890 --> 00:08:38,409 Nå la oss dra til hello.php igjen. 130 00:08:38,409 --> 00:08:42,270 La oss klikke på HTTP-forespørsel til hello.php 131 00:08:42,270 --> 00:08:44,680 og klikk deretter på hoder. 132 00:08:44,680 --> 00:08:50,390 Her kan vi se at cookie header inneholder en nøkkel kalt PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 eller PHP session ID-med en verdi som er det samme lang streng vi så 134 00:08:55,980 --> 00:08:59,290 da vi besøkte sessid.php. 135 00:08:59,290 --> 00:09:04,660 Dette er nøyaktig hvordan nettleseren er minner serveren hva session-ID skal brukes. 136 00:09:04,660 --> 00:09:08,180 Det er blant annet det i en HTTP-header. 137 00:09:08,180 --> 00:09:10,500 OK. La oss dra tilbake til terminalen. 138 00:09:10,500 --> 00:09:16,450 La oss gå til / tmp, der PHP lagrer økten informasjon som standard. 139 00:09:16,450 --> 00:09:19,160 Sikker nok, innsiden av denne midlertidige mappen, 140 00:09:19,160 --> 00:09:23,550 her er en fil som inneholder de samme session-ID. 141 00:09:23,550 --> 00:09:28,990 Hvis vi åpner opp denne filen, kan vi se hvordan PHP representerer min økt på disk. 142 00:09:28,990 --> 00:09:32,870 Her strengen "Tommy" blir lagret for nøkkelen 'navn,' 143 00:09:32,870 --> 00:09:35,750 som er nøyaktig hva vi forventet. 144 00:09:35,750 --> 00:09:38,850 Og det er en oversikt over økter i PHP. 145 00:09:38,850 --> 00:09:42,590 Hva vi nettopp så var bare standard gjennomføring av øktene. 146 00:09:42,590 --> 00:09:45,600 Faktisk, mange nettsteder endre denne standardvirke 147 00:09:45,600 --> 00:09:48,280 til å lagre PHP økter mer effektivt 148 00:09:48,280 --> 00:09:50,390 i interessen for å forbedre ytelsen. 149 00:09:50,390 --> 00:09:52,800 Mitt navn er Tommy, og dette er CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]