1 00:00:00,000 --> 00:00:02,000 [Powered by Google Translate] [PHP Sessões] 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 Sessões em PHP pode ser usado para implementar a funcionalidade, 5 00:00:10,920 --> 00:00:13,440 como logins de usuários, em sua aplicação web. 6 00:00:13,440 --> 00:00:16,920 Sessões PHP permitem associar informações 7 00:00:16,920 --> 00:00:19,680 com toda a sessão de navegação do usuário 8 00:00:19,680 --> 00:00:22,290 ao invés de simplesmente uma única página. 9 00:00:22,290 --> 00:00:27,330 Então isso significa que o usuário visita várias páginas PHP que compõem o seu site, 10 00:00:27,330 --> 00:00:30,630 qualquer informação na sessão persistirá. 11 00:00:30,630 --> 00:00:34,770 Então, o que significa que os dados armazenados na sessão de uma página 12 00:00:34,770 --> 00:00:37,580 mais tarde pode ser acessado por uma outra página. 13 00:00:37,580 --> 00:00:40,080 Armazenando informações em uma sessão é fácil, 14 00:00:40,080 --> 00:00:48,790 e fazemo-lo através do sinal de dólar, sublinhado, variável SESSION capital. 15 00:00:48,790 --> 00:00:52,620 Cifrão, sublinhado, SESSION, exatamente como cifrão, sublinhado, GET 16 00:00:52,620 --> 00:00:54,710 e sinal de dólar, sublinhado, PÓS- 17 00:00:54,710 --> 00:00:58,690 é um array associativo contendo pares de valores-chave. 18 00:00:58,690 --> 00:01:07,980 Assim, podemos usar cifrão sintaxe-like, sublinhado, SESSION, 19 00:01:07,980 --> 00:01:16,000 suporte, citações, foo, citações, suporte, é igual a, citações, bar, cotação on- 20 00:01:16,000 --> 00:01:20,440 para armazenar o valor "bar" na chave "foo". 21 00:01:20,440 --> 00:01:24,030 No entanto, antes de podermos escrever ou ler a partir da matriz de sessão, 22 00:01:24,030 --> 00:01:26,770 vamos precisar chamar uma função-especial 23 00:01:26,770 --> 00:01:34,690 sessão, sublinhado, iniciar () - 24 00:01:34,690 --> 00:01:37,060 e isso irá inicializar a sessão. 25 00:01:37,060 --> 00:01:39,850 Então, vamos dar uma olhada em um exemplo. 26 00:01:39,850 --> 00:01:46,570 Nossa primeira página, ola.php, usa a sessão para a saída de alguns dados para o usuário. 27 00:01:46,570 --> 00:01:53,920 Lembre-se, nós vamos precisar usar session_start antes que possamos acessar quaisquer dados de sessão. 28 00:01:53,920 --> 00:01:59,010 Agora estamos usando isset de PHP para determinar se uma chave existe 29 00:01:59,010 --> 00:02:03,230 na matriz associativa $ _SESSION. 30 00:02:03,230 --> 00:02:07,250 Se essa chave existir, isso significa que o usuário logado, 31 00:02:07,250 --> 00:02:10,410 então vamos exibir o nome do usuário. 32 00:02:10,410 --> 00:02:14,110 Se essa chave não está definido, isso significa que o usuário não tenha registrado no entanto, 33 00:02:14,110 --> 00:02:17,880 então vamos exibir um link para login.php. 34 00:02:17,880 --> 00:02:21,380 Então, vamos dar uma olhada em login.php. 35 00:02:21,380 --> 00:02:26,260 Por aqui, temos um formulário HTML simples com uma única entrada. 36 00:02:26,260 --> 00:02:32,720 Atributo action do formulário é de R $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 e isso significa simplesmente que queremos que o formulário seja enviado ao arquivo atual, 38 00:02:37,440 --> 00:02:41,040 que, nesse caso, é login.php. 39 00:02:41,040 --> 00:02:43,010 Então, vamos voltar ao topo deste arquivo. 40 00:02:43,010 --> 00:02:50,100 Se o usuário enviar o formulário, em seguida, $ _POST ['nome'] deve ser definido. 41 00:02:50,100 --> 00:02:53,750 Para mais informações sobre formulários HTML e post, 42 00:02:53,750 --> 00:02:56,510 confira o vídeo Desenvolvimento Web PHP. 43 00:02:56,510 --> 00:02:59,330 No caso em que o usuário fez enviar o formulário, 44 00:02:59,330 --> 00:03:03,970 nós gostaríamos de escrever o valor que digitei na sessão. 45 00:03:03,970 --> 00:03:08,540 Agora podemos redirecionar o usuário para ola.php. 46 00:03:08,540 --> 00:03:11,800 Porque nós temos guardado a entrada do usuário para a sessão, 47 00:03:11,800 --> 00:03:18,240 ola.php será capaz de acessar o valor que foi definido em login.php. 48 00:03:18,240 --> 00:03:21,010 Então, vamos verificar isso em um navegador web. 49 00:03:21,010 --> 00:03:27,520 Primeiro, vamos navegar até http://localhost/ola.php. 50 00:03:27,520 --> 00:03:30,220 Podemos ver aqui que não se identificou, no entanto, 51 00:03:30,220 --> 00:03:35,040 então vamos clicar no link de login, que irá redirecionar-nos login.php. 52 00:03:35,040 --> 00:03:41,760 Ok, eu vou digitar meu nome, que será, então, armazenados na sessão. 53 00:03:41,760 --> 00:03:48,950 Ótimo! Agora podemos ver a minha entrada de login.php em ola.php via a sessão. 54 00:03:48,950 --> 00:03:52,270 Então, o que dizer de deslogar o usuário? 55 00:03:52,270 --> 00:03:58,510 Bem, a fim de registrar o usuário em, nós simplesmente armazenado um valor em nome da sessão. 56 00:03:58,510 --> 00:04:03,040 Então, para registrar o usuário para fora, nós simplesmente precisamos remover essa chave de nome 57 00:04:03,040 --> 00:04:05,040 a partir da matriz de sessão. 58 00:04:05,040 --> 00:04:09,130 Então, vamos dar uma olhada neste último arquivo, logout.php. 59 00:04:09,130 --> 00:04:12,080 Mais uma vez, vamos ter de chamar session_start () 60 00:04:12,080 --> 00:04:15,260 antes que possamos fazer qualquer coisa relacionada sessão. 61 00:04:15,260 --> 00:04:19,240 Agora podemos simplesmente chamar session_destroy () 62 00:04:19,240 --> 00:04:22,460 que vai cuidar de se livrar de todos os dados da sessão 63 00:04:22,460 --> 00:04:26,790 e, em seguida, redirecionar o usuário de volta para ola.php. 64 00:04:26,790 --> 00:04:30,700 Então, se eu clicar no link Sair, 65 00:04:30,700 --> 00:04:34,690 podemos ver que o servidor tenha esquecido quem eu sou, 66 00:04:34,690 --> 00:04:36,970 e eu já não estou conectado pol 67 00:04:36,970 --> 00:04:39,910 Então, o que está acontecendo aqui debaixo do capô? 68 00:04:39,910 --> 00:04:42,250 A fim de obter o comportamento que acabamos de ver, 69 00:04:42,250 --> 00:04:44,760 nosso servidor precisa fazer 2 coisas. 70 00:04:44,760 --> 00:04:48,980 Em primeiro lugar, o servidor precisa armazenar alguma forma, os dados da sessão. 71 00:04:48,980 --> 00:04:51,910 Os diferentes arquivos PHP que compõem um site 72 00:04:51,910 --> 00:04:56,500 são executados como invocações distintas do interpretador PHP 73 00:04:56,500 --> 00:05:00,550 variável para local não pode ser compartilhado entre eles. 74 00:05:00,550 --> 00:05:04,030 Em vez disso, o servidor precisa para armazenar nossos dados da sessão 75 00:05:04,030 --> 00:05:08,440 em algum lugar que múltiplas. php pode acessar. 76 00:05:08,440 --> 00:05:13,940 Em segundo lugar, o servidor precisa associar os dados da sessão com apenas a minha sessão de navegação. 77 00:05:13,940 --> 00:05:15,940 Quando eu entrar para o Facebook, 78 00:05:15,940 --> 00:05:20,460 provavelmente há milhões de outras pessoas também conectado ao Facebook, ao mesmo tempo. 79 00:05:20,460 --> 00:05:24,200 Mas o servidor precisa de alguma forma de associar os meus dados 80 00:05:24,200 --> 00:05:28,340 com a minha atual sessão e os dados de outra pessoa com outra sessão. 81 00:05:28,340 --> 00:05:32,380 Felizmente, os autores do PHP pensou em tudo isso para nós, 82 00:05:32,380 --> 00:05:35,170 de modo que não precisa implementar nada disso nós mesmos. 83 00:05:35,170 --> 00:05:39,540 Mas vamos dar uma olhada no que o PHP faz por padrão. 84 00:05:39,540 --> 00:05:44,070 Quando eu visitar uma página PHP contendo session_start pela primeira vez, 85 00:05:44,070 --> 00:05:47,930 PHP irá gerar um valor aleatório de grande porte. 86 00:05:47,930 --> 00:05:53,970 Até session_destroy é chamado ou eu não visitar as páginas PHP nesse site por um tempo- 87 00:05:53,970 --> 00:05:59,050 esse valor aleatório e provavelmente único vai ser associado com me. 88 00:05:59,050 --> 00:06:02,780 Dessa forma, o servidor tem alguma forma de identificar a minha sessão de navegação 89 00:06:02,780 --> 00:06:05,710 em oposição a outra pessoa. 90 00:06:05,710 --> 00:06:08,780 Podemos tomar um olhar para o ID da sessão atual 91 00:06:08,780 --> 00:06:12,380 usando a função PHP, session_ID. 92 00:06:12,380 --> 00:06:17,250 Aqui nós estamos simplesmente a saída o valor do nosso identificador de sessão. 93 00:06:17,250 --> 00:06:20,580 Então, se nós de novo login para o web app exemplo, 94 00:06:20,580 --> 00:06:25,530 e agora navegar para sessid.php, 95 00:06:25,530 --> 00:06:27,850 vamos ver essa longa seqüência de caracteres, 96 00:06:27,850 --> 00:06:31,180 e isso é o identificador atual para a minha sessão, 97 00:06:31,180 --> 00:06:35,410 e é assim que o servidor é manter o controle de quem eu sou. 98 00:06:35,410 --> 00:06:37,670 Ok, mas só já resolveu metade do problema. 99 00:06:37,670 --> 00:06:40,910 Claro, o servidor agora tem alguma forma de me identificar, 100 00:06:40,910 --> 00:06:46,060 mas quando eu visitar outra página, o servidor precisa reutilizar esse mesmo identificador 101 00:06:46,060 --> 00:06:48,910 em vez de gerar um novo. 102 00:06:48,910 --> 00:06:52,760 Lembre-se, se eu declarar uma variável local em foo.php 103 00:06:52,760 --> 00:06:55,190 e depois visite bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php tem nenhuma maneira de saber o que aconteceu no foo.php. 105 00:07:00,980 --> 00:07:07,450 Assim, a implementação sessão php padrão requer que o navegador lembrar o servidor 106 00:07:07,450 --> 00:07:09,740 qual sessão ID para usar. 107 00:07:09,740 --> 00:07:12,710 Isto é implementado sob a forma de um biscoito. 108 00:07:12,710 --> 00:07:15,370 Um cookie-além de ser um delicioso lanche- 109 00:07:15,370 --> 00:07:18,630 é simplesmente um pequeno arquivo de texto em seu computador 110 00:07:18,630 --> 00:07:21,780 que um servidor pode escrever a via navegador web. 111 00:07:21,780 --> 00:07:27,300 Então, depois de PHP gera minha sessão exclusiva de identificação via session_start, 112 00:07:27,300 --> 00:07:34,210 ele vai dizer o navegador web para armazenar esse identificador em um arquivo de texto local, ou um cookie. 113 00:07:34,210 --> 00:07:38,490 Em seguida, o navegador web irá incluir esse identificador em cada pedido 114 00:07:38,490 --> 00:07:40,780 que faz com que o servidor. 115 00:07:40,780 --> 00:07:44,280 Então, realmente, o servidor web não é lembrar quem eu sou. 116 00:07:44,280 --> 00:07:48,780 Em vez disso, o navegador web é simplesmente lembrar o identificador único 117 00:07:48,780 --> 00:07:52,730 que foi gerado pelo PHP e, em seguida, constantemente lembrando o servidor 118 00:07:52,730 --> 00:07:55,120 o que esse identificador é. 119 00:07:55,120 --> 00:08:00,760 Dessa forma, informações como o meu nome de usuário é armazenado no servidor não é meu navegador. 120 00:08:00,760 --> 00:08:05,190 O browser simplesmente diz ao servidor onde o PHP armazenada essa informação 121 00:08:05,190 --> 00:08:07,750 assim PHP pode recuperá-lo. 122 00:08:07,750 --> 00:08:12,150 Assim que levanta a questão: onde está o PHP realmente armazenar essa informação? 123 00:08:12,150 --> 00:08:14,910 Por padrão, o PHP irá armazenar os dados da sessão 124 00:08:14,910 --> 00:08:19,540 em um arquivo dentro de / tmp, ou a pasta 'temp'. 125 00:08:19,540 --> 00:08:24,450 O nome do arquivo que irá incluir a ID da sessão para que o PHP pode determinar 126 00:08:24,450 --> 00:08:28,620 qual arquivo para ler e escrever a partir de via apenas o ID da sessão. 127 00:08:28,620 --> 00:08:32,280 Tudo bem. Então, vamos abrir a guia Rede no depurador do Chrome 128 00:08:32,280 --> 00:08:34,890 através do ícone de chave inglesa no canto superior direito. 129 00:08:34,890 --> 00:08:38,409 Agora vamos ir ao ola.php novamente. 130 00:08:38,409 --> 00:08:42,270 Vamos clicar sobre a solicitação HTTP para ola.php 131 00:08:42,270 --> 00:08:44,680 e, em seguida, clique em cabeçalhos. 132 00:08:44,680 --> 00:08:50,390 Aqui podemos ver que o cabeçalho cookie contém uma chave chamada PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 ou sessão PHP ID-com um valor que é que mesma seqüência muito tempo vimos 134 00:08:55,980 --> 00:08:59,290 quando visitamos sessid.php. 135 00:08:59,290 --> 00:09:04,660 Isto é exatamente como o navegador está lembrando o servidor que ID de sessão deve ser usado. 136 00:09:04,660 --> 00:09:08,180 É incluí-lo em um cabeçalho HTTP. 137 00:09:08,180 --> 00:09:10,500 Tudo bem. Vamos voltar para o terminal. 138 00:09:10,500 --> 00:09:16,450 Vamos navegar para / tmp, onde o PHP está armazenando as informações da sessão, por padrão. 139 00:09:16,450 --> 00:09:19,160 Com certeza, dentro desta pasta temporária, 140 00:09:19,160 --> 00:09:23,550 aqui está um arquivo que contém o mesmo ID da sessão exata. 141 00:09:23,550 --> 00:09:28,990 Se abrir este arquivo, podemos ver como o PHP está representando minha sessão no disco. 142 00:09:28,990 --> 00:09:32,870 Aqui, a string "Tommy" está sendo armazenado para a chave 'nome' 143 00:09:32,870 --> 00:09:35,750 que é exatamente o que nós esperávamos. 144 00:09:35,750 --> 00:09:38,850 E isso é uma visão geral de sessões em PHP. 145 00:09:38,850 --> 00:09:42,590 O que acabamos de ver foi só a implementação padrão de sessões. 146 00:09:42,590 --> 00:09:45,600 Na verdade, muitos sites alterar esse comportamento padrão 147 00:09:45,600 --> 00:09:48,280 para armazenar as sessões PHP mais eficientemente 148 00:09:48,280 --> 00:09:50,390 no interesse de melhorar o desempenho. 149 00:09:50,390 --> 00:09:52,800 Meu nome é Tommy, e essa é CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]