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, la Universitat de Harvard] 3 00:00:04,000 --> 00:00:07,000 [Aquest és CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Sessions en PHP es poden utilitzar per implementar la funcionalitat, 5 00:00:10,920 --> 00:00:13,440 com els inicis de sessió dels usuaris, en la seva aplicació web. 6 00:00:13,440 --> 00:00:16,920 Sessions de PHP li permeten associar informació 7 00:00:16,920 --> 00:00:19,680 amb tota la sessió de navegació de l'usuari 8 00:00:19,680 --> 00:00:22,290 en lloc de limitar-se a una sola pàgina. 9 00:00:22,290 --> 00:00:27,330 Així que això significa que l'usuari visita diverses pàgines PHP que componen el seu lloc web, 10 00:00:27,330 --> 00:00:30,630 qualsevol informació a la sessió persistirà. 11 00:00:30,630 --> 00:00:34,770 Així que això significa que les dades emmagatzemades a la sessió per una pàgina 12 00:00:34,770 --> 00:00:37,580 més tard es pot accedir per una altra pàgina. 13 00:00:37,580 --> 00:00:40,080 L'emmagatzematge d'informació en una sessió és fàcil, 14 00:00:40,080 --> 00:00:48,790 i ho fem a través de la mostra de dòlar, subratllat, variable SESSION capital. 15 00:00:48,790 --> 00:00:52,620 Signe de dòlar, subratllen, SESSIÓ-igual que el signe de dòlar, el subratllat, GET 16 00:00:52,620 --> 00:00:54,710 i el signe de dòlar, subratllat, POST- 17 00:00:54,710 --> 00:00:58,690 és un array associatiu consistent en parells de valors clau. 18 00:00:58,690 --> 00:01:07,980 Així que podem usar el signe de dòlar-com sintaxi, subratllat, REUNIÓ, 19 00:01:07,980 --> 00:01:16,000 suport, cita, menjar, cita, suport, és igual, cita, bar, cita- 20 00:01:16,000 --> 00:01:20,440 per emmagatzemar el "bar" valor en la clau "foo". 21 00:01:20,440 --> 00:01:24,030 No obstant això, abans de poder escriure o llegir de la matriu de la sessió, 22 00:01:24,030 --> 00:01:26,770 haurem de cridar a una funció especial 23 00:01:26,770 --> 00:01:34,690 sessió, subratllen, iniciar, () - 24 00:01:34,690 --> 00:01:37,060 i això va a inicialitzar la sessió. 25 00:01:37,060 --> 00:01:39,850 Així que donem una ullada a un exemple. 26 00:01:39,850 --> 00:01:46,570 La nostra primera pàgina, hello.php, utilitza la sessió a la sortida d'algunes dades per a l'usuari. 27 00:01:46,570 --> 00:01:53,920 Recordeu, nosaltres haurem de fer servir session_start abans de poder accedir a les dades de la sessió. 28 00:01:53,920 --> 00:01:59,010 Ara estem utilitzant isset de PHP per determinar si hi ha una clau 29 00:01:59,010 --> 00:02:03,230 a la matriu associatiu $ _SESSION. 30 00:02:03,230 --> 00:02:07,250 Si existeix aquesta clau, això significa que l'usuari ha iniciat la sessió, 31 00:02:07,250 --> 00:02:10,410 així que anem a mostrar el nom de l'usuari. 32 00:02:10,410 --> 00:02:14,110 Si no s'estableix aquesta clau, això significa que l'usuari no ha iniciat sessió encara, 33 00:02:14,110 --> 00:02:17,880 així que mostrarem un enllaç a login.php. 34 00:02:17,880 --> 00:02:21,380 Així que donem una ullada a login.php. 35 00:02:21,380 --> 00:02:26,260 Aquí sota, tenim un únic formulari HTML amb una sola entrada. 36 00:02:26,260 --> 00:02:32,720 Atribut action del formulari és de $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 i això simplement vol dir que volem que el formulari que es presentarà a la imatge actual, 38 00:02:37,440 --> 00:02:41,040 que, en aquest cas, és login.php. 39 00:02:41,040 --> 00:02:43,010 Així que anem a tornar a la part superior d'aquest arxiu. 40 00:02:43,010 --> 00:02:50,100 Si l'usuari envia el formulari, a continuació, $ _POST ['name'] s'ha d'establir. 41 00:02:50,100 --> 00:02:53,750 Per obtenir més informació sobre els formularis HTML i post, 42 00:02:53,750 --> 00:02:56,510 veure el vídeo de Desenvolupament Web PHP. 43 00:02:56,510 --> 00:02:59,330 En el cas que l'usuari fer enviar el formulari, 44 00:02:59,330 --> 00:03:03,970 ens agradaria escriure el valor que ells escriuen en en la sessió. 45 00:03:03,970 --> 00:03:08,540 Ara podem redirigir l'usuari a hello.php. 46 00:03:08,540 --> 00:03:11,800 Com que hem emmagatzemat l'entrada de l'usuari en la sessió, 47 00:03:11,800 --> 00:03:18,240 hello.php podran accedir al valor que es va establir a login.php. 48 00:03:18,240 --> 00:03:21,010 Així que anem a veure això en un navegador web. 49 00:03:21,010 --> 00:03:27,520 En primer lloc, anem a navegar a http://localhost/hola.php. 50 00:03:27,520 --> 00:03:30,220 Podem veure aquí que no hem registrat encara, 51 00:03:30,220 --> 00:03:35,040 així que anem a fer clic a l'enllaç d'inici de sessió, el que ens redirigirà a login.php. 52 00:03:35,040 --> 00:03:41,760 Està bé, t'escric en nom meu, que després s'emmagatzema en la sessió. 53 00:03:41,760 --> 00:03:48,950 Great! Ara podem veure la meva entrada de login.php en hello.php a través de la sessió. 54 00:03:48,950 --> 00:03:52,270 Així que, què passa amb el registre l'usuari sortir? 55 00:03:52,270 --> 00:03:58,510 Bé, amb la finalitat de registrar l'usuari que, simplement guardar un valor en nom de la sessió. 56 00:03:58,510 --> 00:04:03,040 Així que per registrar l'usuari fora, simplement hem de treure aquesta clau de nom 57 00:04:03,040 --> 00:04:05,040 de la matriu de la sessió. 58 00:04:05,040 --> 00:04:09,130 Així que donem una ullada a aquest últim arxiu, logout.php. 59 00:04:09,130 --> 00:04:12,080 Un cop més, haurem de trucar a session_start () 60 00:04:12,080 --> 00:04:15,260 abans de poder fer qualsevol cosa relacionada amb la sessió. 61 00:04:15,260 --> 00:04:19,240 Ara podem simplement cridar session_destroy (), 62 00:04:19,240 --> 00:04:22,460 que s'encarregarà de desfer-se de totes les dades de la sessió 63 00:04:22,460 --> 00:04:26,790 i després redireccionar al'usuari a hello.php. 64 00:04:26,790 --> 00:04:30,700 Així que si faig clic a l'enllaç de la sessió, 65 00:04:30,700 --> 00:04:34,690 podem veure que el servidor s'ha oblidat del que sóc, 66 00:04:34,690 --> 00:04:36,970 i ja no estic logged in 67 00:04:36,970 --> 00:04:39,910 Llavors, què està passant aquí sota de la caputxa? 68 00:04:39,910 --> 00:04:42,250 Per tal d'obtenir el comportament que acabem de veure, 69 00:04:42,250 --> 00:04:44,760 nostre servidor ha de fer 2 coses. 70 00:04:44,760 --> 00:04:48,980 En primer lloc, el servidor necessita per emmagatzemar d'alguna manera les dades de la sessió. 71 00:04:48,980 --> 00:04:51,910 Els diferents arxius PHP que componen una pàgina web 72 00:04:51,910 --> 00:04:56,500 s'executen com invocacions separades de l'intèrpret PHP 73 00:04:56,500 --> 00:05:00,550 variable, de manera local no es pot compartir entre ells. 74 00:05:00,550 --> 00:05:04,030 En el seu lloc, el servidor necessita per emmagatzemar les nostres dades de la sessió 75 00:05:04,030 --> 00:05:08,440 en algun lloc que múltiples. php poden accedir. 76 00:05:08,440 --> 00:05:13,940 En segon lloc, el servidor ha de associar les dades de la sessió només amb la meva sessió de navegació. 77 00:05:13,940 --> 00:05:15,940 Quan em connecto a Facebook, 78 00:05:15,940 --> 00:05:20,460 probablement hi ha milions d'altres persones també connectat a Facebook al mateix temps. 79 00:05:20,460 --> 00:05:24,200 No obstant això, el servidor necessita alguna manera d'associar les meves dades 80 00:05:24,200 --> 00:05:28,340 amb el meu actual període de sessions i les dades d'una altra persona amb una altra sessió. 81 00:05:28,340 --> 00:05:32,380 Per sort, els autors de PHP pensaven sobre tot això per a nosaltres, 82 00:05:32,380 --> 00:05:35,170 així que no hem de posar en pràctica tot això nosaltres mateixos. 83 00:05:35,170 --> 00:05:39,540 Però donem una ullada al que PHP fa per defecte. 84 00:05:39,540 --> 00:05:44,070 Quan visito una pàgina PHP que conté session_start per primera vegada, 85 00:05:44,070 --> 00:05:47,930 PHP generar un gran valor aleatori. 86 00:05:47,930 --> 00:05:53,970 Fins session_destroy es diu-o jo no visitar les pàgines PHP en aquest lloc per un temps- 87 00:05:53,970 --> 00:05:59,050 aquest valor aleatori i probablement únic s'associarà a mi. 88 00:05:59,050 --> 00:06:02,780 D'aquesta forma el servidor té alguna forma d'identificar la meva sessió de navegació 89 00:06:02,780 --> 00:06:05,710 en lloc d'una altra persona. 90 00:06:05,710 --> 00:06:08,780 Podem fer una ullada a la identificació de la sessió actual 91 00:06:08,780 --> 00:06:12,380 utilitzant la funció de PHP, SESSION_ID. 92 00:06:12,380 --> 00:06:17,250 Aquí estem simplement emetre el valor del nostre identificador de sessió. 93 00:06:17,250 --> 00:06:20,580 Així que si tornem a iniciar sessió en l'aplicació d'exemple web, 94 00:06:20,580 --> 00:06:25,530 i ara navegar fins sessid.php, 95 00:06:25,530 --> 00:06:27,850 anem a veure aquesta llarga cadena de caràcters, 96 00:06:27,850 --> 00:06:31,180 i aquest és l'identificador actual de la meva sessió, 97 00:06:31,180 --> 00:06:35,410 i així és com el servidor és fer el seguiment del que sóc. 98 00:06:35,410 --> 00:06:37,670 Està bé, però només hem solucionat la meitat del problema. 99 00:06:37,670 --> 00:06:40,910 És clar, el servidor ara té alguna forma d'identificar, 100 00:06:40,910 --> 00:06:46,060 però en la meva visita a una altra pàgina, el servidor ha de tornar a utilitzar el mateix identificador 101 00:06:46,060 --> 00:06:48,910 en lloc de generar una nova. 102 00:06:48,910 --> 00:06:52,760 Recordeu, si jo declaro una variable local a foo.php 103 00:06:52,760 --> 00:06:55,190 ia continuació, visiteu Bar.php, 104 00:06:55,190 --> 00:07:00,980 Bar.php no té manera de saber el que va passar a foo.php. 105 00:07:00,980 --> 00:07:07,450 De manera que l'aplicació de sessions php defecte requereix que el navegador recordi al servidor 106 00:07:07,450 --> 00:07:09,740 que l'ID de sessió per utilitzar. 107 00:07:09,740 --> 00:07:12,710 Això s'implementa en forma d'una galeta. 108 00:07:12,710 --> 00:07:15,370 Una galeta-a més de ser un deliciós berenar- 109 00:07:15,370 --> 00:07:18,630 és simplement un petit arxiu de text a l'ordinador 110 00:07:18,630 --> 00:07:21,780 que un servidor pot escriure a través del navegador web. 111 00:07:21,780 --> 00:07:27,300 Així que després de PHP genera meva única identificació de la sessió a través d'session_start, 112 00:07:27,300 --> 00:07:34,210 que va a dir-li al navegador web per emmagatzemar aquest identificador en un arxiu de text local, o una galeta. 113 00:07:34,210 --> 00:07:38,490 A continuació, el navegador web inclourà aquest identificador a cada petició 114 00:07:38,490 --> 00:07:40,780 que fa al servidor. 115 00:07:40,780 --> 00:07:44,280 Així que en realitat, el servidor web no és recordar qui sóc. 116 00:07:44,280 --> 00:07:48,780 En canvi, el navegador web és simplement recordant l'identificador únic 117 00:07:48,780 --> 00:07:52,730 que va ser generada per PHP i després recordant constantment el servidor 118 00:07:52,730 --> 00:07:55,120 el que és l'identificador. 119 00:07:55,120 --> 00:08:00,760 D'aquesta manera, la informació de la mateixa manera que el meu nom d'usuari s'emmagatzema al servidor, no el navegador web. 120 00:08:00,760 --> 00:08:05,190 El navegador simplement li diu al servidor on PHP emmagatzema aquesta informació 121 00:08:05,190 --> 00:08:07,750 pel que PHP pot recuperar-la. 122 00:08:07,750 --> 00:08:12,150 Així que planteja la pregunta, on és realment PHP emmagatzemant aquesta informació? 123 00:08:12,150 --> 00:08:14,910 Per defecte, PHP emmagatzemar les seves dades de sessió 124 00:08:14,910 --> 00:08:19,540 en un arxiu dins de / tmp, oa la carpeta "temp". 125 00:08:19,540 --> 00:08:24,450 El nom d'aquest arxiu s'inclourà la identificació de la sessió pel que PHP pot determinar 126 00:08:24,450 --> 00:08:28,620 un arxiu a llegir i escriure a través de només l'identificador de sessió. 127 00:08:28,620 --> 00:08:32,280 Està bé. Així que anem a obrir la fitxa Xarxa en el depurador de Chrome 128 00:08:32,280 --> 00:08:34,890 a través de la icona de clau anglesa a la part superior dreta. 129 00:08:34,890 --> 00:08:38,409 Ara anem al capdavant a hello.php nou. 130 00:08:38,409 --> 00:08:42,270 Farem clic sobre la sol · licitud HTTP per hello.php 131 00:08:42,270 --> 00:08:44,680 i després feu clic a capçaleres. 132 00:08:44,680 --> 00:08:50,390 Aquí podem veure que la capçalera de galeta conté una clau anomenada PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 o sessió de PHP-ID amb un valor que és aquesta mateixa llarga cadena que vam veure 134 00:08:55,980 --> 00:08:59,290 quan visitem sessid.php. 135 00:08:59,290 --> 00:09:04,660 Així és exactament com el navegador està recordant al servidor què ID de sessió s'ha d'usar. 136 00:09:04,660 --> 00:09:08,180 Està inclosa en una capçalera HTTP. 137 00:09:08,180 --> 00:09:10,500 Està bé. Tornem a la terminal. 138 00:09:10,500 --> 00:09:16,450 Anem a navegar a / tmp, on PHP emmagatzema la informació de la sessió per defecte. 139 00:09:16,450 --> 00:09:19,160 Efectivament, a l'interior d'aquesta carpeta temporal, 140 00:09:19,160 --> 00:09:23,550 aquí hi ha un arxiu que conté exactament el mateix ID de sessió. 141 00:09:23,550 --> 00:09:28,990 Si obrim l'arxiu, podem veure com PHP està representant la meva sessió en el disc. 142 00:09:28,990 --> 00:09:32,870 Aquí la cadena "Tommy" s'està emmagatzemant per a la clau 'nom' 143 00:09:32,870 --> 00:09:35,750 que és exactament el que estàvem esperant. 144 00:09:35,750 --> 00:09:38,850 I això és una visió general de les sessions en PHP. 145 00:09:38,850 --> 00:09:42,590 El que acabem de veure va ser només la implementació per defecte de sessions. 146 00:09:42,590 --> 00:09:45,600 De fet, molts llocs web canvien aquest comportament predeterminat 147 00:09:45,600 --> 00:09:48,280 per emmagatzemar les sessions de PHP de manera més eficient 148 00:09:48,280 --> 00:09:50,390 en l'interès de millorar el rendiment. 149 00:09:50,390 --> 00:09:52,800 El meu nom és Tommy, i això és CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]