1 00:00:00,000 --> 00:00:02,000 [Powered by Google Translate] [PHP Sesións] 2 00:00:02,000 --> 00:00:04,000 [Tommy MacWilliam, Harvard University] 3 00:00:04,000 --> 00:00:07,000 [Isto é CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Sesións en PHP se pode usar para aplicar a función, 5 00:00:10,920 --> 00:00:13,440 como logins de usuarios, na súa aplicación web. 6 00:00:13,440 --> 00:00:16,920 Sesións PHP permiten asociar información 7 00:00:16,920 --> 00:00:19,680 con toda a sesión de navegación do usuario 8 00:00:19,680 --> 00:00:22,290 en vez de simplemente unha única páxina. 9 00:00:22,290 --> 00:00:27,330 Entón iso significa que o usuario visita varias páxinas PHP que compoñen a súa web, 10 00:00:27,330 --> 00:00:30,630 calquera información na sesión persistirá. 11 00:00:30,630 --> 00:00:34,770 Entón, o que significa que os datos almacenados na sesión de unha páxina 12 00:00:34,770 --> 00:00:37,580 máis tarde se pode acceder por outra páxina. 13 00:00:37,580 --> 00:00:40,080 Almacenando información nunha sesión é doado, 14 00:00:40,080 --> 00:00:48,790 e facémolo a través do sinal de dólar, subliñado, variable SESSION capital. 15 00:00:48,790 --> 00:00:52,620 Cifrão, subliñado, SESSION, exactamente como cifrão, subliñado, GET 16 00:00:52,620 --> 00:00:54,710 e sinal de dólar, subliñado, pos- 17 00:00:54,710 --> 00:00:58,690 é un array asociativo contén pares de valores clave. 18 00:00:58,690 --> 00:01:07,980 Así, podemos usar cifrão sintaxis-like, subliñado, SESSION, 19 00:01:07,980 --> 00:01:16,000 soporte, multimedia, foo, multimedia, soporte, é igual a, multimedia, bar, cotización en 20 00:01:16,000 --> 00:01:20,440 para almacenar o valor "bar" na clave "foo". 21 00:01:20,440 --> 00:01:24,030 Con todo, antes de podermos escribir ou ler a partir da matriz de sesión, 22 00:01:24,030 --> 00:01:26,770 imos ter chamar a unha función-especial 23 00:01:26,770 --> 00:01:34,690 sesión, subliñado, comezar () - 24 00:01:34,690 --> 00:01:37,060 e isto pode inicializar a sesión. 25 00:01:37,060 --> 00:01:39,850 Entón, imos dar un ollo a un exemplo. 26 00:01:39,850 --> 00:01:46,570 A nosa primeira páxina, ola.php, usa a sesión para a saída de algúns datos para o usuario. 27 00:01:46,570 --> 00:01:53,920 Lembre, nós imos ter usar session_start antes de que poidamos acceder os datos de sesión. 28 00:01:53,920 --> 00:01:59,010 Agora estamos usando isset de PHP para determinar se unha chave existe 29 00:01:59,010 --> 00:02:03,230 na matriz asociativa $ _SESSION. 30 00:02:03,230 --> 00:02:07,250 Se esa clave existir, isto significa que o usuario rexistrado, 31 00:02:07,250 --> 00:02:10,410 entón imos ver o nome do usuario. 32 00:02:10,410 --> 00:02:14,110 Se esta chave non está definido, isto significa que o usuario non teña rexistrado con todo, 33 00:02:14,110 --> 00:02:17,880 entón imos ver unha ligazón a login.php. 34 00:02:17,880 --> 00:02:21,380 Entón, imos dar un ollo a login.php. 35 00:02:21,380 --> 00:02:26,260 Por aquí, temos un formulario HTML sinxelo cunha única entrada. 36 00:02:26,260 --> 00:02:32,720 Atributo action do formulario é de R $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 e iso significa simplemente que queremos que o formulario sexa enviado ao arquivo actual, 38 00:02:37,440 --> 00:02:41,040 que, nese caso, é login.php. 39 00:02:41,040 --> 00:02:43,010 Entón, imos volver ao inicio deste ficheiro. 40 00:02:43,010 --> 00:02:50,100 O usuario enviar o formulario, a continuación, $ _POST ['nome'] debe ser definido. 41 00:02:50,100 --> 00:02:53,750 Para máis información sobre formularios HTML e post, 42 00:02:53,750 --> 00:02:56,510 Escribe o vídeo Desenvolvemento web PHP. 43 00:02:56,510 --> 00:02:59,330 No caso de que o usuario fixo enviar o formulario, 44 00:02:59,330 --> 00:03:03,970 nós queremos escribir o valor que escriba na sesión. 45 00:03:03,970 --> 00:03:08,540 Agora podemos redireccionar o usuario para ola.php. 46 00:03:08,540 --> 00:03:11,800 Porque temos gardado a entrada do usuario para a sesión, 47 00:03:11,800 --> 00:03:18,240 ola.php poderá acceder o valor que se definiu en login.php. 48 00:03:18,240 --> 00:03:21,010 Entón, imos comprobar iso nun navegador web. 49 00:03:21,010 --> 00:03:27,520 En primeiro lugar, imos navegar ata http://localhost/ola.php. 50 00:03:27,520 --> 00:03:30,220 Podemos ver aquí que non se identificou, con todo, 51 00:03:30,220 --> 00:03:35,040 entón imos premer na ligazón de rexistro, que pode redireccionar connosco login.php. 52 00:03:35,040 --> 00:03:41,760 Ok, eu vou escribir o meu nome, que será, entón, almacenados na sesión. 53 00:03:41,760 --> 00:03:48,950 Gran! Agora podemos ver a miña entrada de login.php en ola.php vía a sesión. 54 00:03:48,950 --> 00:03:52,270 Entón, o que dicir de deslogar o usuario? 55 00:03:52,270 --> 00:03:58,510 Así, a fin de rexistrar o usuario en, simplemente almacenado un valor en nome da sesión. 56 00:03:58,510 --> 00:04:03,040 Entón, para rexistrar o usuario para fóra, nós simplemente necesitamos eliminar esa clave de nome 57 00:04:03,040 --> 00:04:05,040 a partir da matriz de sesión. 58 00:04:05,040 --> 00:04:09,130 Entón, imos dar un ollo neste último arquivo, logout.php. 59 00:04:09,130 --> 00:04:12,080 Unha vez máis, imos ter que chamar session_start () 60 00:04:12,080 --> 00:04:15,260 antes de que poidamos facer calquera cousa relacionada sesión. 61 00:04:15,260 --> 00:04:19,240 Agora podemos simplemente chamar session_destroy () 62 00:04:19,240 --> 00:04:22,460 que vai coidar de se librar de todos os datos da sesión 63 00:04:22,460 --> 00:04:26,790 e logo, redireccionar ao usuario de volta a ola.php. 64 00:04:26,790 --> 00:04:30,700 Entón, se eu premer na ligazón Saír, 65 00:04:30,700 --> 00:04:34,690 vemos que o servidor teña esquecido quen eu son, 66 00:04:34,690 --> 00:04:36,970 e eu xa non estou conectado Pol 67 00:04:36,970 --> 00:04:39,910 Entón, o que está pasando aquí debaixo do capo? 68 00:04:39,910 --> 00:04:42,250 Co fin de obter o comportamento que acabamos de ver, 69 00:04:42,250 --> 00:04:44,760 noso servidor que facer 2 cousas. 70 00:04:44,760 --> 00:04:48,980 En primeiro lugar, o servidor ten que gardar dalgunha forma, os datos da sesión. 71 00:04:48,980 --> 00:04:51,910 Os distintos ficheiros PHP que compoñen un sitio 72 00:04:51,910 --> 00:04:56,500 son executados como invocacións distintas do intérprete PHP 73 00:04:56,500 --> 00:05:00,550 variable para local non pode ser compartido entre eles. 74 00:05:00,550 --> 00:05:04,030 Pola contra, o servidor precisa para almacenar os nosos datos da sesión 75 00:05:04,030 --> 00:05:08,440 en algún lugar que múltiples. php pode acceder. 76 00:05:08,440 --> 00:05:13,940 En segundo lugar, o servidor ten que asociar os datos da sesión con só a miña sesión de navegación. 77 00:05:13,940 --> 00:05:15,940 Cando entrar no Facebook, 78 00:05:15,940 --> 00:05:20,460 probablemente hai millóns de outras persoas tamén conectado a Facebook, á vez. 79 00:05:20,460 --> 00:05:24,200 Pero o servidor precisa algunha forma de asociar os meus datos 80 00:05:24,200 --> 00:05:28,340 coa miña actual sesión e os datos de outra persoa con outra sesión. 81 00:05:28,340 --> 00:05:32,380 Por sorte, os autores de PHP pensou en todo isto para nós, 82 00:05:32,380 --> 00:05:35,170 de xeito que non precisa aplicar nada diso nós mesmos. 83 00:05:35,170 --> 00:05:39,540 Pero imos dar un ollo ao que o PHP fai por omisión. 84 00:05:39,540 --> 00:05:44,070 Cando visitar unha páxina PHP contén session_start por primeira vez, 85 00:05:44,070 --> 00:05:47,930 PHP pode xerar un valor aleatorio de grande porte. 86 00:05:47,930 --> 00:05:53,970 Ata session_destroy chámase ou eu non visitar as páxinas PHP nese sitio por un tempo- 87 00:05:53,970 --> 00:05:59,050 ese valor aleatorio e probablemente único será asociado con me. 88 00:05:59,050 --> 00:06:02,780 Desa forma, o servidor ten algunha forma de identificar a miña sesión de navegación 89 00:06:02,780 --> 00:06:05,710 en oposición a outra persoa. 90 00:06:05,710 --> 00:06:08,780 Podemos tomar un ollar para o ID da sesión actual 91 00:06:08,780 --> 00:06:12,380 usando a función PHP, session_ID. 92 00:06:12,380 --> 00:06:17,250 Aquí estamos simplemente a saída o valor do noso identificador de sesión. 93 00:06:17,250 --> 00:06:20,580 Entón, se nós de novo sesión para o web app exemplo, 94 00:06:20,580 --> 00:06:25,530 e agora navegar a sessid.php, 95 00:06:25,530 --> 00:06:27,850 imos ver esa longa secuencia de caracteres, 96 00:06:27,850 --> 00:06:31,180 e iso é o identificador actual para a miña sesión, 97 00:06:31,180 --> 00:06:35,410 e é así que o servidor é manter o control de quen eu son. 98 00:06:35,410 --> 00:06:37,670 Ok, pero só xa resolveu a metade do problema. 99 00:06:37,670 --> 00:06:40,910 Por suposto, o servidor agora ten algunha forma de me identificar, 100 00:06:40,910 --> 00:06:46,060 pero cando visitar outra páxina, o servidor ten que reutilizar ese mesmo identificador 101 00:06:46,060 --> 00:06:48,910 en vez de xerar un novo. 102 00:06:48,910 --> 00:06:52,760 Teña en conta que, se eu declarar unha variable local en foo.php 103 00:06:52,760 --> 00:06:55,190 e despois visita bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php ten ningunha forma de saber o que pasou no foo.php. 105 00:07:00,980 --> 00:07:07,450 Así, a posta en marcha sesión php estándar require que o navegador lembrar o servidor 106 00:07:07,450 --> 00:07:09,740 cal sesión ID para usar. 107 00:07:09,740 --> 00:07:12,710 Isto é aplicado en forma de un biscoito. 108 00:07:12,710 --> 00:07:15,370 Unha cookie-ademais de ser un delicioso lanche- 109 00:07:15,370 --> 00:07:18,630 é simplemente un pequeno arquivo de texto no teu ordenador 110 00:07:18,630 --> 00:07:21,780 que un servidor pode escribir a vía navegador web. 111 00:07:21,780 --> 00:07:27,300 Entón, despois de PHP xera miña sesión exclusiva de identificación vía session_start, 112 00:07:27,300 --> 00:07:34,210 que vai dicir o navegador web para almacenar este identificador nun arquivo de texto local, ou unha cookie. 113 00:07:34,210 --> 00:07:38,490 A continuación, o navegador web debería incluír este identificador en cada solicitude 114 00:07:38,490 --> 00:07:40,780 que fai que o servidor. 115 00:07:40,780 --> 00:07:44,280 Entón, realmente, o servidor web non é lembrar quen eu son. 116 00:07:44,280 --> 00:07:48,780 Pola contra, o navegador web é simplemente lembrar o identificador único 117 00:07:48,780 --> 00:07:52,730 que foi xerado polo PHP e logo, constantemente lembrando o servidor 118 00:07:52,730 --> 00:07:55,120 o que este identificador é. 119 00:07:55,120 --> 00:08:00,760 Desta forma, a información como o meu nome de usuario é almacenado no servidor non é o meu navegador. 120 00:08:00,760 --> 00:08:05,190 O navegador simplemente di ao servidor onde PHP almacenada a información 121 00:08:05,190 --> 00:08:07,750 así PHP pode recuperalo. 122 00:08:07,750 --> 00:08:12,150 Así que levanta a cuestión: onde está o PHP realmente almacenar esa información? 123 00:08:12,150 --> 00:08:14,910 Por defecto, o PHP pode almacenar os datos da sesión 124 00:08:14,910 --> 00:08:19,540 nun arquivo dentro / tmp, ou o cartafol 'tempo'. 125 00:08:19,540 --> 00:08:24,450 O nome do ficheiro que debería incluír o ID da sesión para que o PHP pode determinar 126 00:08:24,450 --> 00:08:28,620 o ficheiro para ler e escribir a partir de vía só o ID de sesión. 127 00:08:28,620 --> 00:08:32,280 Todo ben. Entón, imos abrir a guía Rede no depurador de Chrome 128 00:08:32,280 --> 00:08:34,890 a través da icona de chave inglesa na esquina superior dereita. 129 00:08:34,890 --> 00:08:38,409 Agora imos ir ao ola.php novo. 130 00:08:38,409 --> 00:08:42,270 Imos facer clic sobre a solicitude HTTP para ola.php 131 00:08:42,270 --> 00:08:44,680 e, en continuación, prema en cabeceiras. 132 00:08:44,680 --> 00:08:50,390 Aquí podemos ver que a cabeceira cookie contén unha chave chamada PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 ou sesión PHP ID-cun valor que é que mesma secuencia moito tempo vimos 134 00:08:55,980 --> 00:08:59,290 cando visitamos sessid.php. 135 00:08:59,290 --> 00:09:04,660 Isto é exactamente como o navegador está lembrando o servidor que ID de sesión debe ser usado. 136 00:09:04,660 --> 00:09:08,180 É inclui-lo en unha cabeceira HTTP. 137 00:09:08,180 --> 00:09:10,500 Todo ben. Imos volver para o terminal. 138 00:09:10,500 --> 00:09:16,450 Imos ir a / tmp, onde o PHP está almacenando a información da sesión, por defecto. 139 00:09:16,450 --> 00:09:19,160 Seguramente, dentro deste cartafol temporal, 140 00:09:19,160 --> 00:09:23,550 aquí está un arquivo que contén o mesmo ID da sesión exacta. 141 00:09:23,550 --> 00:09:28,990 Se abrir este ficheiro, podemos ver como o PHP está representando a miña sesión no disco. 142 00:09:28,990 --> 00:09:32,870 Aquí, a cadea "Tommy" está a ser almacenado para a chave 'nome' 143 00:09:32,870 --> 00:09:35,750 que é o que nós esperabamos. 144 00:09:35,750 --> 00:09:38,850 E iso é unha visión xeral de sesións en PHP. 145 00:09:38,850 --> 00:09:42,590 O que acabamos de ver foi só a implementación estándar de sesións. 146 00:09:42,590 --> 00:09:45,600 De feito, moitos sitios cambiar este comportamento predeterminado 147 00:09:45,600 --> 00:09:48,280 para gardar as sesións PHP máis eficiente 148 00:09:48,280 --> 00:09:50,390 no interese de mellorar o rendemento. 149 00:09:50,390 --> 00:09:52,800 O meu nome é Tommy, e esa é CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]