Laboratorio: Captura de pacotes HTTP: mudanças entre as edições
De Wiki Cursos IFPR Foz
Ir para navegaçãoIr para pesquisar
(17 revisões intermediárias pelo mesmo usuário não estão sendo mostradas) | |||
Linha 2: | Linha 2: | ||
Fonte: <ref>http://wiki.sj.ifsc.edu.br/wiki/index.php/RED29004-2015-1</ref>. | Fonte: <ref>http://wiki.sj.ifsc.edu.br/wiki/index.php/RED29004-2015-1</ref>. | ||
; | ;Requisitos de software: Este laboratório utiliza a ferramenta de captura de pacotes '''Wireshark'''. | ||
:*Para utilizar o '''Wireshark''' é necessário que o administrador atribua permissão para os usuários normais poderem executá-lo. | |||
: | :*Outra opção é utilizar uma '''máquina virtual''' com a placa de rede configurada em modo '''''bridge''''' e com permissão de administrador e instalar os aplicativos e utilizar o '''Wireshark'''. | ||
:Veja no link '''[[wireshark]]''' as instruções para download e instalação do '''Wireshark''', bem como as instruções para uso do ferramenta. | |||
==Objetivos== | ==Objetivos== | ||
O objetivo deste laboratório é estudar o funcionamento da '''[[Aplicação Web]]''' e explorar o funcionamento do ''' | O objetivo deste laboratório é estudar o funcionamento da '''[[Aplicação Web]]''' e explorar o funcionamento do '''[[Protocolo HTTP]]''', incluindo as '''mensagens de pedido e resposta''' e a '''memória ''cache'' do navegador'''<!--, acesso a '''arquivos HTML grandes''' e '''arquivos HTML com objetos incluídos'''-->. | ||
==Pedido e Resposta HTTP== | ==Pedido e Resposta HTTP== | ||
Vamos iniciar a nossa exploração do HTTP baixando um arquivo em HTML | Vamos iniciar a nossa exploração do HTTP baixando um arquivo em HTML simples. | ||
;Procedimentos: | ;Procedimentos: | ||
#Inicie o navegador; | #Verifique com '''ifconfig''' a configuração de sua interface de rede; | ||
#Inicie o Wireshark e | #Inicie o navegador '''Firefox''' e não abra nenhuma página Web; | ||
#Inicie o Wireshark, em seguida selecione a '''placa de rede''' e nas '''opções de captura''' selecione o '''filtro http''', de tal forma que apenas as mensagens HTTP capturadas serão exibidas na janela de listagem de pacotes. ; | |||
#Inicie a captura de pacotes | #Inicie a captura de pacotes | ||
#Digite | #Digite no navegador a URL para acessar o seu servidor Web com a página padrão ou uma página HTML simples; | ||
#Pare a captura de pacotes. | #Pare a captura de pacotes. | ||
Linha 32: | Linha 34: | ||
#Qual o número da porta TCP utilizada no seu computador e pelo servidor? | #Qual o número da porta TCP utilizada no seu computador e pelo servidor? | ||
#Qual o endereço MAC do seu computador? | #Qual o endereço MAC do seu computador? | ||
#Qual o código de ''status'' retornado do servidor para o seu navegador? | #Qual o código de ''status'' retornado do servidor para o seu navegador? | ||
#Quando o arquivo em HTML que você baixou foi modificado no servidor pela última vez? | #Quando o arquivo em HTML que você baixou foi modificado no servidor pela última vez? | ||
#Quantos bytes de conteúdo são baixados pelo seu navegador? | #Quantos bytes de conteúdo são baixados pelo seu navegador? | ||
== | ==Pedido HTTP GET Condicional e Resposta== | ||
A maioria dos navegadores web tem uma '''memória ''cache''''' que permite armazenar as últimas páginas acessadas. Desta forma o | A maioria dos navegadores web tem uma '''memória ''cache''''' que permite armazenar as últimas páginas acessadas. Desta forma o navegador realiza um '''GET condicional''' quando busca um objeto HTTP a fim de verificar se o objeto em ''cache'' é o mesmo que está sendo provido pelo servidor. | ||
;Procedimentos: | ;Procedimentos: | ||
#Inicie o navegador web; | #Inicie o navegador web; | ||
#Limpe o '''''cache''''' do seu navegador | #Limpe o '''''cache''''' do seu navegador: | ||
#:Firefox: Preferências -> Privacidade e Segurança -> Cookies e Dados de Sites; | |||
#Inicie o Wireshark e selelcione o filtro '''http''', de tal forma que apenas as mensagens HTTP capturadas serão exibidas na janela de listagem de pacotes. ; | #Inicie o Wireshark e selelcione o filtro '''http''', de tal forma que apenas as mensagens HTTP capturadas serão exibidas na janela de listagem de pacotes. ; | ||
#Digite | #Digite a uma URL no navegador; | ||
#Visualize os | #Visualize os pacotes capturados; | ||
#Pressione o botão “atualizar” no navegador; | #Pressione o botão “atualizar” no navegador; | ||
#Pare a captura de pacotes. | #Pare a captura de pacotes. | ||
Linha 57: | Linha 59: | ||
#O servidor retornou explicitamente o conteúdo do arquivo? Explique. | #O servidor retornou explicitamente o conteúdo do arquivo? Explique. | ||
#Qual o tamanho da primeira e segunda mensagem de retorno do servidor? | #Qual o tamanho da primeira e segunda mensagem de retorno do servidor? | ||
<!-- | |||
==Baixando Documentos Longos== | ==Baixando Documentos Longos== | ||
Linha 82: | Linha 84: | ||
#No segundo GET realizado, quantos segmentos TCP foram necessários para obtenção da resposta do servidor? | #No segundo GET realizado, quantos segmentos TCP foram necessários para obtenção da resposta do servidor? | ||
#O que explica a diferença entre a primeira e segunda requisições? | #O que explica a diferença entre a primeira e segunda requisições? | ||
;Análise dos pacotes TCP capturados: | ;Análise dos pacotes TCP capturados: | ||
#Modifique o filtro de análise para visualizar pacotes TCP e porta 80; | #Modifique o filtro de análise para visualizar pacotes TCP e porta 80; | ||
Linha 89: | Linha 91: | ||
#Verifique os reconhecimentos dos dados recebidos; | #Verifique os reconhecimentos dos dados recebidos; | ||
#Verifique o encerramento da conexão TCP. | #Verifique o encerramento da conexão TCP. | ||
==Documentos HTML com Objetos Incluídos== | ==Documentos HTML com Objetos Incluídos== | ||
Linha 106: | Linha 107: | ||
#Veja como cada figura foi transportada nos segmentos TCP. Houve fragmentação? | #Veja como cada figura foi transportada nos segmentos TCP. Houve fragmentação? | ||
===Autenticação HTTP=== | ===Autenticação HTTP=== | ||
Linha 148: | Linha 143: | ||
---- | ---- | ||
[[Usuário:Evandro.cantu|Evandro.cantu]] ([[Usuário Discussão:Evandro.cantu|discussão]]) 17h40min de 26 de abril de 2021 (-03) | |||
---- | ---- | ||
[[Categoria:Redes de Computadores]] | [[Categoria:Redes de Computadores]] |
Edição atual tal como às 12h23min de 3 de maio de 2021
Laboratório: Captura de pacotes HTTP
Fonte: [1].
- Requisitos de software
- Este laboratório utiliza a ferramenta de captura de pacotes Wireshark.
- Para utilizar o Wireshark é necessário que o administrador atribua permissão para os usuários normais poderem executá-lo.
- Outra opção é utilizar uma máquina virtual com a placa de rede configurada em modo bridge e com permissão de administrador e instalar os aplicativos e utilizar o Wireshark.
- Veja no link wireshark as instruções para download e instalação do Wireshark, bem como as instruções para uso do ferramenta.
Objetivos
O objetivo deste laboratório é estudar o funcionamento da Aplicação Web e explorar o funcionamento do Protocolo HTTP, incluindo as mensagens de pedido e resposta e a memória cache do navegador.
Pedido e Resposta HTTP
Vamos iniciar a nossa exploração do HTTP baixando um arquivo em HTML simples.
- Procedimentos
- Verifique com ifconfig a configuração de sua interface de rede;
- Inicie o navegador Firefox e não abra nenhuma página Web;
- Inicie o Wireshark, em seguida selecione a placa de rede e nas opções de captura selecione o filtro http, de tal forma que apenas as mensagens HTTP capturadas serão exibidas na janela de listagem de pacotes. ;
- Inicie a captura de pacotes
- Digite no navegador a URL para acessar o seu servidor Web com a página padrão ou uma página HTML simples;
- Pare a captura de pacotes.
- Análise dos pacotes capturados
- Verifique a mensagem GET (enviada pelo seu navegador para o servidor) e a mensagem de resposta do servidor para o seu navegador;
- Verifique os detalhes da mensagem GET;
- Verifique o encapsulamento dos protocolos, com a mensagem HTTP sendo transportada em um segmento TCP, que é carregado em um datagrama IP, que por sua vez é levado em um quadro Ethernet.
- Perguntas
- O seu navegador executa HTTP 1.0 ou 1.1?
- Qual a versão de HTTP do servidor?
- Quais idiomas o seu navegador indica que pode aceitar ao servidor?
- Qual o endereço IP do seu computador e do servidor?
- Qual o número da porta TCP utilizada no seu computador e pelo servidor?
- Qual o endereço MAC do seu computador?
- Qual o código de status retornado do servidor para o seu navegador?
- Quando o arquivo em HTML que você baixou foi modificado no servidor pela última vez?
- Quantos bytes de conteúdo são baixados pelo seu navegador?
Pedido HTTP GET Condicional e Resposta
A maioria dos navegadores web tem uma memória cache que permite armazenar as últimas páginas acessadas. Desta forma o navegador realiza um GET condicional quando busca um objeto HTTP a fim de verificar se o objeto em cache é o mesmo que está sendo provido pelo servidor.
- Procedimentos
- Inicie o navegador web;
- Limpe o cache do seu navegador:
- Firefox: Preferências -> Privacidade e Segurança -> Cookies e Dados de Sites;
- Inicie o Wireshark e selelcione o filtro http, de tal forma que apenas as mensagens HTTP capturadas serão exibidas na janela de listagem de pacotes. ;
- Digite a uma URL no navegador;
- Visualize os pacotes capturados;
- Pressione o botão “atualizar” no navegador;
- Pare a captura de pacotes.
- Perguntas
- Inspecione o conteúdo da primeira mensagem HTTP GET do seu navegador para o servidor. Você vê uma linha If-Modified-Since?
- Inspecione o conteúdo da resposta do servidor. O servidor retornou explicitamente o conteúdo do arquivo? Como você pode dizer isso?
- Agora inspecione o conteúdo da segunda mensagem HTTP GET do seu navegador para o servidor. Você vê uma linha If-Modified-Since? Caso a resposta seja afirmativa, qual informação segue o cabeçalho If-Modified-Since?
- Qual é o código de status e a frase retornada do servidor na resposta à segunda mensagem HTTP GET? É diferente do código de retorno da primeira mensagem?
- O servidor retornou explicitamente o conteúdo do arquivo? Explique.
- Qual o tamanho da primeira e segunda mensagem de retorno do servidor?
Referências
Evandro.cantu (discussão) 17h40min de 26 de abril de 2021 (-03)