Bcc361-2014-02 - p6 Camada de Aplicacao

Fazer download em pdf ou txt
Fazer download em pdf ou txt
Você está na página 1de 89

Camada

  Nome  

BCC361  –  Redes  de  Computadores   5   Aplicação  

4   Transporte  
Universidade  Federal  de  Ouro  Preto   3   Rede  
Departamento  de  Ciência  da  Computação   2   Enlace  

  1   Física  

Prof.  Reinaldo  Fortes  /  Saul  Delabrida  


www.decom.ufop.br/reinaldo  
2014/02  

Camada  de  Aplicação   1  

BCC361  
2014/02  
Agenda  
•  Introdução;  
•  DNS  (Domain  Name  System);  
•  Correio  Eletrônico;  
•  A  World  Wide  Web  (WWW).  

2  

BCC361  
2014/02  
Introdução;  
DNS  (Domain  Name  System);  
Correio  Eletrônico;  
A  World  Wide  Web  (WWW).  

INTRODUÇÃO   3  

BCC361  
2014/02  
Introdução  

Tópicos  
•  A  Camada  de  Aplicação;  
•  Arquitetura  de  aplicação  de  rede;  
•  Protocolos  da  camada  de  aplicação.  

4  

BCC361  
2014/02  
Introdução  

A  Camada  de  Aplicação  


•  Aplicações  são  a  razão  de  ser  de  uma  rede  de  computadores;  

•  Se  não  fosse  possível  disponibilizar  aplicações  úteis,  não  


haveria  necessidade  de  projetar  protocolos  de  rede  para  
suportá-­‐las;  

•  Assim,  a  camada  de  aplicação  oferece  serviços  diretamente  


para  o  usuário  através  de  todo  o  arcabouço  estudado  até  o  
momento.  

5  

BCC361  
2014/02  
Introdução  

A  Camada  de  Aplicação  


•  O  cerne  do  desenvolvimento  de  aplicação  de  rede  é  escrever  
programas  que  rodem  em  sistemas  finais  diferentes  e  que  se  
comuniquem  entre  si  pela  rede,  exemplos:  
•  Numa  aplicação  Web  há  dois  programas  dis]ntos:    
•  O  browser  que  roda  na  máquina  cliente;  
•  E  o  servidor  Web,  que  roda  na  máquina  do  servidor;  
•  Em  um  compar]lhamento  de  arquivos  P2P:  
•  Existem  programas  em  cada  máquina  que  par]cipa  do  
compar]lhamento;  
•  Estes  programas  podem  ser  idên]cos  ou  semelhantes;  

•  A  base  das  aplicações  é  a  interação  cliente-­‐servidor  e  a  


comunicação  entre  pares.   6  

BCC361  
2014/02  
Introdução  

Arquitetura  de  aplicação  de  rede  


•  A  arquitetura  da  aplicação  determina  como  a  aplicação  é  
organizada  nos  vários  sistemas  finais;  
•  Arquitetura  de  aplicação  é  diferente  da  arquitetura  de  rede;  

•  Duas  arquiteturas  mais  u]lizadas  em  aplicações  modernas:  


•  Cliente-­‐servidor;  
•  Peer-­‐to-­‐Peer  (P2P).  

7  

BCC361  
2014/02  
Introdução  

Arquitetura  de  aplicação  de  rede  


•  Arquitetura  Cliente-­‐Servidor:  
•  Há  um  hospedeiro  sempre  em  funcionamento:  o  servidor;  
•  O  servidor  possui  um  endereço  fixo  e  bem  conhecido;  
•  O  servidor  atende  a  requisições  de  muitos  outros  hospedeiros,  os  
clientes;  
•  Clientes  não  precisam  estar  sempre  em  funcionamento;  
•  Clientes  não  se  comunicam  diretamente  uns  com  os  outros;  
•  Exemplos  de  aplicações:  
•  Web;  
•  FTP;  
•  Telnet;  
•  E-­‐mail.  
8  

BCC361  
2014/02  
Introdução  

Arquitetura  de  aplicação  de  rede  


•  Arquitetura  Peer-­‐to-­‐Peer  (P2P):  
•  A  comunicação  ocorre  de  forma  direta  entre  pares  de  
hospedeiros;  
•  Estes  pares  não  são  de  propriedade  de  provedores  de  serviços,  
mas  são  controlados  por  usuários  finais;  
•  Assim,  não  há  garan]as  de  que  os  pares  estejam  sempre  em  
funcionamento;  
•  Exemplos  de  aplicações:  
•  BitTorrent;  
•  eMule;  
•  LimeWire;  
•  Skype;  
•  PPLive  (aplicação  de  IPTV).   9  

BCC361  
2014/02  
Introdução  

Protocolos  da  camada  de  aplicação  


•  Definem  como  os  processos  de  uma  aplicação  trocam  
mensagens  entre  si,  em  par]cular:  
•  Tipos  de  mensagens  trocadas,  por  exemplo,  de  requisição  e  
resposta;  
•  A  sintaxe  dos  vários  ]pos  de  mensagens,  tais  como  os  campos  da  
mensagem  e  como  os  campos  são  delimitados;  
•  A  semân]ca  dos  campos,  isto  é,  o  significado  da  sua  informação;  
•  Regras  para  determinar  quando  e  como  um  processo  envia  e  
responde  mensagens.  

10  

BCC361  
2014/02  
Introdução  

Protocolos  da  camada  de  aplicação  


•  Alguns  protocolos  da  camada  de  aplicação  estão  definidos  em  
RFCs,  ou  seja,  são  de  domínio  público;  
•  Exemplo:  HTTP  (protocolo  da  Web)  –  RFC  2616;  

•  Outros  são  proprietários  e  não  estão  disponíveis  ao  público;  


•  Exemplo:  A  maioria  dos  sistemas  de  compar]lhamento  de  
arquivos  P2P;  

•  Um  protocolo  da  camada  de  aplicação  é  apenas  uma  parte  da  


aplicação  de  rede;  
•  Exemplo:  O  HTTP  é  o  protocolo  da  Web,  que  por  sua  vez  é  
composta  de  vários  outros  elementos:  formato  de  documentos  
(HTML),  browsers  (Firefox,  Chrome),  servidores  (Apache,  
11  
MicrosoA),  etc...  
BCC361  
2014/02  
Introdução;  
DNS  (Domain  Name  System);  
Correio  Eletrônico;  
A  World  Wide  Web  (WWW).  

DNS  (DOMAIN  NAME  SYSTEM)   12  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Tópicos  
•  Introdução;  
•  O  ambiente  de  nomes;  
•  Registros  de  recursos;  
•  Servidores  de  nomes.  

13  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Introdução  
•  Imagine  acessar  os  sites  de  seu  interesse  através  do  IP*:  
•  UFOP:  200.131.208.21  (www.ufop.br);  
•  Terra:  200.154.56.80  (www.terra.com.br);  
•  UOL:  200.221.2.45  (www.uol.com.br);  
•  TwiRer:  199.59.150.39  (www.twiner.com);  
•  Google:  74.125.234.56  (www.google.com.br);  
•  Google:  74.125.234.49  (www.google.com);  

*  IPs  obEdos  por  ping  em  12/03/2013.  

•  Problemas:  
•  Se  lembrar  de  cada  endereço  IP;  
•  Endereços  IP  podem  mudar;  

•  Solução:  Criar  um  serviço  de  nomes  de  alto  nível.   14  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Introdução  
•  Na  ARPANET  havia  apenas  um  arquivo  que  con]nha  
mapeamentos  Nome  /  IP  (hosts.txt):  
•  Para  poucos  hosts  isto  pode  funcionar;  
•  Mas  para  milhões  de  hosts  conectados  não;  

•  Assim  foi  criado  o  sistema  de  nomes  e  domínios,  o  DNS,  


Domain  Name  System;  
•  Definido  nas  RFCs  1034,  1035,  2181;  
•  Detalhado  em  várias  outras;  

15  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Introdução  
•  Funcionamento  básico:  
•  Uma  aplicação  faz  uma  chamada  a  um  procedimento  de  
biblioteca  denominado  resolvedor,  passando  como  parâmetro  o  
nome  a  ser  “resolvido”;  
•  O  resolvedor  envia  uma  consulta  contendo  o  nome  para  um  
servidor  DNS  local;  
•  Este  servidor  retorna  com  o  endereço  IP  ao  resolvedor;  
•  O  resolvedor  repassa  o  endereço  retornado  para  a  aplicação;  

•  As  mensagens  de  consulta  e  resposta  são  enviadas  como  


mensagens  UDP;  
•  De  posse  do  IP  a  aplicação  pode  estabelecer  o  ]po  de  
comunicação  de  sua  escolha.   16  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

O  ambiente  de  nomes  


•  Os  nomes  são  definidos  em  uma  estrutura  hierárquica  (1/3):  

•  Domínio  de  nível  superior:  genéricos  e  de  países;  


•  Cada  nível  define  um  domínio  independente  e  autônomo;   17  
•  Cada  domínio  controla  seus  próprios  subdomínios;  
BCC361  
2014/02  
DNS  (Domain  Name  System)  

O  ambiente  de  nomes  


•  Os  nomes  são  definidos  em  uma  estrutura  hierárquica  (2/3):  

•  A  informação  é  distribuída  pelos  vários  servidores  da  rede;  


•  Escalável  (não  há  centralização  de  dados);   18  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

O  ambiente  de  nomes  


•  Os  nomes  são  definidos  em  uma  estrutura  hierárquica  (3/3):  

•  O  nome  do  domínio  é  ascendente  e  não  haverá  conflitos;  


•  eng.cisco.com,  departamento  de  engenharia  da  Cisco;   19  
•  eng.washington.edu,  departamento  de  língua  inglesa  da  
Universidade  de  Washington.  
BCC361  
2014/02  
DNS  (Domain  Name  System)  

Registros  de  recursos  


•  Cada  domínio  pode  ter  um  registro  de  recursos  (um  banco  de  
dados  DNS)  associado  a  ele;  

•  Para  um  host  comum  o  registro  de  recursos  costuma  ser  


composto  apenas  pelo  seu  endereço  IP,  mas  existem  muitos  
outros  ]pos;  

•  Quando  um  resolvedor  repassa  um  nome  de  domínio  a  um  


servidor  DNS,  ele  recebe  na  verdade  os  registros  de  recursos  
associados  a  ele;  

•  Portanto,  a  principal  tarefa  do  servidor  DNS  é  mapear  nomes   20  


de  domínios  em  registros  de  recursos.  
BCC361  
2014/02  
DNS  (Domain  Name  System)  

Registros  de  recursos  


•  Um  registro  de  recursos  é  uma  tupla  de  cinco  campos:  
1.  Nome_dominio;  
2.  Tempo_de_vida;  
3.  Classe;  
4.  Tipo;  
5.  Valor.  

21  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Registros  de  recursos  


1.  Nome_dominio:  
•  Informa  a  qual  domínio  o  registro  se  aplica;  
•  Normalmente  um  mesmo  domínio  possui  vários  registros;  
•  Cada  cópia  do  banco  de  dados  possui  informações  de  vários  
domínios;  
•  A  ordem  dos  registros  não  é  significa]va.  

22  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Registros  de  recursos  


2.  Tempo_de_vida:  
•  Define  um  tempo  para  validade  do  registro;  
•  Registros  mais  estáveis  recebem  tempos  maiores;  

4.  Classe:  
•  Para  informações  relacionadas  à  Internet  recebe  valor  IN;  
•  Existem  outras  classes,  mas  raramente  são  u]lizadas  na  prá]ca.  

23  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Registros  de  recursos  


4.  Tipo:  
•  Informa  o  ]po  do  registro;  
5.  Valor:  
•  Valor  associado  ao  registro;  
•  Tipos  mais  significa]vos  e  seus  valores:  
Tipo   Significado   Valor  
A   Endereço  IPv4.   Inteiro  de  32  bits.  
AAAA   Endereço  IPv6.   Inteiro  de  128  bits.  
MX   Troca  de  mensagens  de  correio   Prioridade,  domínio  disposto  a  aceitar  
eletrônico.   correio  eletrônico.  
NS   Servido  de  nomes.   Nome  para  um  servidor  para  este  domínio.  
CNAME   Nome  canônico   Nome  de  domínio.   24  
PTR   Ponteiro.   Nome  alterna]vo  de  um  endereço  IP.  
SRV   Serviço.   Host  que  oferece  o  serviço.   BCC361  
2014/02  
DNS  (Domain  Name  System)  

Registros  de  recursos  


•  Parte  de  uma  possível  base  de  dados  DNS:  

25  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Servidores  de  nomes  


•  Por  que  usar  servidores?  Apenas  um  não  resolveria?  
•  Na  teoria  sim,  mas  na  prá]ca  seria  impossível;  
•  Problemas  de  sobrecarga  e  alta  dependência  inviabilizam  esta  
solução;  
•  Assim,  o  espaço  de  nomes  do  DNS  é  dividido  em  zonas  não  
sobrepostas,  exemplo:  

26  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Servidores  de  nomes  


•  Cada  zona  está  associada  a  um  ou  mais  servidores  de  nomes;  

•  Estes  servidores  mantêm  o  banco  de  dados  da  zona;  

•  Normalmente  uma  zona  terá  um  servidor  de  nomes  primário,  


que  recebe  a  informação  de  um  arquivo  em  seu  disco,  e  
servidores  de  nomes  secundários,  que  recebem  informações  
do  servidor  primário;  

•  Para  melhoria  de  confiabilidade,    alguns  servidores  de  nomes  


podem  estar  localizados  fora  da  zona.  
27  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Servidores  de  nomes  


•  O  processo  de  pesquisa  de  um  nome  e  localização  de  um  
endereço  é  chamado  resolução  de  nomes;  

•  Um  registro  oficial  é  aquele  que  vem  da  autoridade  oficial  que  


controla  o  registro,  portanto,  está  sempre  correto;  

•  Um  registro  de  cache  é  aquele  retornado  por  um  servidor  que  


armazenou  temporariamente  a  informação  por  questão  de  
performance,  portanto,  pode  estar  desatualizado.  

28  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Servidores  de  nomes  


•  Exemplo  de  resolução  de  nome:  

29  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Servidores  de  nomes  


•  Dois  mecanismos  de  consulta:  

•  Consulta  recursiva:  o  servidor  de  nomes  local  retorna  a  resposta  


final  ao  originador,  fazendo  quantas  chamadas  forem  necessárias  
a  outros  servidores  de  nome  (representado  na  figura  anterior);  

•  Consulta  itera]va:  o  servidor  de  nomes  apenas  retorna  uma  


resposta  parcial,  com  a  informação  que  lhe  compete,  não  realiza  
chamadas  a  outros  servidores  para  completar  a  resposta.  

30  

BCC361  
2014/02  
DNS  (Domain  Name  System)  

Servidores  de  nomes  


•  Mecanismo  de  caching:  

•  Todas  as  respostas,  incluindo  as  parciais,  são  armazenadas  em  


cache  para  atendimento  rápido  a  novas  solicitações;  

•  Caso  haja  solicitações  para  um  host  diferente  de  um  mesmo  
domínio,  o  caminho  é  encurtado  fazendo  uma  solicitação  direta  
ao  servidor  de  nomes  oficial,  sem  passar  por  servidores  de  
hierarquias  mais  altas;  

•  O  cache  melhora  a  performance,  mas  deve  haver  cuidado  com  as  


possíveis  alterações  de  informações,  por  isso  cada  registro  de  
recurso  possui  um  campo  TTL  (tempo  de  vida).   31  

BCC361  
2014/02  
Introdução;  
DNS  (Domain  Name  System);  
Correio  Eletrônico;  
A  World  Wide  Web  (WWW).  

CORREIO  ELETRÔNICO   32  

BCC361  
2014/02  
Correio    Eletrônico  

Tópicos  
•  Introdução;  
•  Arquitetura  e  serviços;  
•  Agente  do  usuário;  
•  Formato  de  mensagens;  
•  Transferência  de  mensagem;  
•  Entrega  final.  

33  

BCC361  
2014/02  
Correio    Eletrônico  

Introdução  
•  O  correio  eletrônico,  ou  e-­‐mail,  já  existe  há  muito  tempo,  
mais  de  duas  décadas;  

•  Muito  mais  rápido  e  barato  que  o  sistema  de  correios  


convencional;  

•  Uma  das  aplicações  mais  populares  desde  os  primeiros  dias  da  
Internet;  

•  Infelizmente,  a  maior  parte  dos  e-­‐mails  é  lixo,  ou  spam.  

34  

BCC361  
2014/02  
Correio    Eletrônico  

Introdução  

•  Os  protocolos  também  evoluíram  com  o  tempo;  


•  Dos  e-­‐mail  com  texto  ASCII  puro  a  mensagens  com  formato  
HTML,  som,  imagem,  etc.;  

•  Também  evoluíram  os  meios  de  acesso  aos  e-­‐mails;  


•  Aplicações  de  leitura  de  e-­‐mail  (Outlook,  Mozilla  Thunderbird,  
etc.)  e  Webmails;  

35  

BCC361  
2014/02  
Correio    Eletrônico  

Arquitetura  e  serviços  
•  Principais  serviços:  
•  Composição;  
•  Transferência;  
•  Relatórios;  
•  Exibição;  

•  Subsistemas  divididos  em:  


•  Agentes  de  usuário;  
•  Agentes  de  transferência;  

36  

BCC361  
2014/02  
Correio    Eletrônico  

Arquitetura  e  serviços  
•  Arquitetura  do  sistema  de  e-­‐mails  (1/3):  

•  Agentes  do  usuário  transmissor:  permitem  que  as  pessoas  leiam  


e  enviem  mensagens;  
•  Agentes  de  transferência  de  mensagens:  deslocam  as  
mensagens  da  origem  ao  des]no.  Também  denominados  
servidores  de  correio;   37  

BCC361  
2014/02  
Correio    Eletrônico  

Arquitetura  e  serviços  
•  Arquitetura  do  sistema  de  e-­‐mails  (2/3):  

•  O  ato  de  enviar  uma  mensagem  é  denominado  submissão  de  e-­‐


mail;  
•  A  etapa  de  transferência  da  mensagem  é  feita  u]lizando  o  
protocolo  SMTP  (Simple  Mail  Transfer  Protocol);  
38  

BCC361  
2014/02  
Correio    Eletrônico  

Arquitetura  e  serviços  
•  Arquitetura  do  sistema  de  e-­‐mails  (3/3):  

•  As  Caixas  de  Correio  armazenam  os  e-­‐mails  recebidos  para  um  


usuário:  
•  São  man]das  pelos  servidores  de  correio;  
•  Os  agentes  de  usuário  simplesmente  apresentam  aos  usuários  uma  
visão  das  caixas  de  correio,  eventualmente  permi]ndo  o   39  
armazenamento  local  e  a  eliminação  das  mensagens  no  servidor.  
BCC361  
2014/02  
Correio    Eletrônico  

Arquitetura  e  serviços  
•  O  e-­‐mail  é  enviado  entre  os  agentes  de  transferência  seguindo  
um  formato  padrão:  
•  Formato  original  é  definido  na  RFC  822;  
•  Revisado  na  RFC  5322,  e  estendido  com  suporte  para  conteúdo  
mul]mídia  e  texto  internacional  (MIME);  

•  A  ideia  principal  no  formato  da  mensagem  é  a  dis]nção  entre  


o  envelope  da  mensagem  e  seu  conteúdo  (corpo);  
•  O  envelope  contém  toda  a  informação  necessária  para  
transportar  a  mensagem;  
•  O  conteúdo  é  inteiramente  direcionado  para  o  des]natário.  
40  

BCC361  
2014/02  
Correio    Eletrônico  

Agente  do  usuário  


•  Um  agente  de  usuário  é  um  programa  (às  vezes  denominado  
leitor  de  e-­‐mail)  que  aceita  uma  série  de  comandos  para  
compor,  receber  e  responder  mensagens,  além  de  manipular  
caixas  de  correio;  

•  Existem  muitos  agentes  de  usuário:  


•  Gmail  da  Google;  
•  MicrosoA  Outlook;  
•  Mozilla  Thunderbird;  
•  Apple  Mail;  
•  Etc...;  
41  

BCC361  
2014/02  
Correio    Eletrônico  

Formato  de  mensagens  


•  As  mensagens  precisam  ser  colocadas  em  um  formato  padrão  
para  serem  manipuladas  pelos  agentes  de  transferência;  

•  Inicialmente  as  mensagens  con]nham  apenas  texto  em  


formato  ASCII  (RFC  5322  /  822);  

•  Depois  foram  aprimoradas  para  possibilitar  conteúdo  


mul]mídia  e  múl]plos  idiomas  (MIME);  

42  

BCC361  
2014/02  
Correio    Eletrônico  

Formato  de  mensagens  


•  RFC  5322  –  Formato  de  mensagem  da  Internet  (1):  
•  Mensagens  consistem  de  um  envelope  básico,  alguns  campos  de  
cabeçalho,  uma  linha  em  branco  e  o  corpo  da  mensagem;  
•  Principais  campos  do  cabeçalho,  relacionados  ao  transporte:  
Campo   Significado  
To:   Os  endereços  de  correio  eletrônico  dos  des]natários  principais.  
Cc:   Os  endereços  de  correio  eletrônico  dos  des]natários  secundários.  
Cco:   Os  endereços  de  correio  eletrônico  dos  des]natários  ocultos.  
From:   As  pessoas  que  criaram  a  mensagem.  
Sender:   Endereço  de  e-­‐mail  do  remetente.  
Received:   Linha  incluída  por  cada  agente  de  transferência  ao  longo  da  rota  
(iden]dade  do  agente,  data,  hora  de  recebimento,  entre  outras).   43  
Return-­‐ Pode  ser  incluída  para  iden]ficar  um  caminho  de  volta  ao  
Path:   remetente.   BCC361  
2014/02  
Correio    Eletrônico  

Formato  de  mensagens  


•  RFC  5322  –  Formato  de  mensagem  da  Internet  (2):  
•  Adicionalmente  outros  campos  de  cabeçalho  podem  ser  
u]lizados  pelos  agentes  ou  des]natários:  
Campo   Significado  
Date:   Data  e  hora  em  que  a  mensagem  foi  enviada.  
Replay-­‐To:   Endereço  de  e-­‐mail  para  onde  as  respostas  devem  ser  enviadas.  
Message-­‐Id:   Número  exclusivo  que  será  usado  para  fazer  referência  à  
mensagem  posteriormente.  
Keywords:   Palavras-­‐chave  do  usuário.  
Subject:   Pequeno  texto  de  resumo  da  mensagem  apresentados  em  
apenas  uma  linha.  

•  Usuários  podem  criar  novos  cabeçalhos  para  seu  uso;   44  


•  Eles  devem  começar  com  “X-­‐”.  
BCC361  
2014/02  
Correio    Eletrônico  

Formato  de  mensagens  


•  MIME  –  Mu>purpose  Internet  Mail  Extensions  (1/3):  
•  Nos  anos  90  o  uso  mundial  da  Internet  e  a  demanda  por  
conteúdo  mais  rico  através  do  sistema  de  e-­‐mail  mostrou  que  o  
protocolo  anterior  não  era  mais  adequado;  

•  Para  resolver  esta  questão  foi  desenvolvido  o  MIME,  que  além  de  
ser  u]lizado  para  mensagens  enviadas  pela  Internet  também  é  
u]lizado  para  definir  conteúdo  para  outras  aplicações,  como  a  
navegação  Web;  

•  Descrito  nas  RFCs  2045  –  2047,  4288,  4289  e  2049;  

•  A  ideia  é  con]nuar  a  usar  o  formato  da  RFC  822,  mas  incluir  uma  
estrutura  para  o  corpo  da  mensagem  e  definir  regras  para   45  
mensagens  que  não  u]lizam  o  ASCII.  
BCC361  
2014/02  
Correio    Eletrônico  

Formato  de  mensagens  


•  MIME  –  Mu>purpose  Internet  Mail  Extensions  (2/3):  
•  Permite:  
•  Mensagens  em  idiomas  com  acentos;  
•  Mensagens  em  alfabetos  não  la]nos;  
•  Mensagens  em  idiomas  sem  alfabetos;  
•  Mensagens  que  não  contêm  textos;  
•  Cabeçalhos  de  mensagens  acrescentados:  
Campo   Significado  
MIME-­‐Version:   Iden]fica  a  versão  do  MIME.  
Content-­‐Descrip]on:   String  inteligível  que  iden]fica  o  conteúdo  da  mensagem.  
Content-­‐Id:   Iden]ficador  exclusivo.  
Content-­‐Transfer-­‐ Como  o  corpo  da  mensagem  é  codificado  para   46  
Encoding:   transmissão.  
Content-­‐Type:   Tipo  e  formato  de  conteúdo.   BCC361  
2014/02  
Correio    Eletrônico  

Formato  de  mensagens  


•  MIME  –  Mu>purpose  Internet  Mail  Extensions  (3/3):  
•  Tipos  de  conteúdo  MIME  e  exemplos  de  sub]pos:  

Tipo   Sub]pos  de  exemplo   Descrição  


text   plain,  html,  xml,  css   Texto  em  vários  formatos.  
image   gif,  jpeg,  ]ff   Imagens.  
audio   basic,  mpeg,  mp4   Sons.  
video   mpeg,  mp4,  quick]me   Filmes.  
model   vrml   Modelo  3D.  
applica]on   octect-­‐stream,  pdf,   Dados  produzidos  por  aplicações.  
javascript,  zip  
message   hnp,  rfc822   Mensagem  encapsulada  (exemplo:  
encaminhamento  de  mensagem).   47  
mul]part   mixed,  alterna]ve,   Combinação  de  vários  ]pos.  
parallel,  digest   BCC361  
2014/02  
Correio    Eletrônico  

Transferência  de  mensagem  


•  A  transferência  de  mensagens  é  feita  u]lizando-­‐se  do  
protocolo  SMTP  (Simple  Mail  Transfer  Protocol);  

•  A  transferência  no  SMTP  é  feita  através  de  uma  conexão  TCP  


na  porta  25;  

•  Trata-­‐se  de  um  protocolo  simples,  que  usa  o  ASCII;  

•  Não  são  necessários  checksums,  porque  o  TCP  fornece  fluxo  


de  bytes  confiável.  

48  

BCC361  
2014/02  
Correio    Eletrônico  

Transferência  de  mensagem  


•  O  SMTP  básico  funciona  bem,  mas  possui  algumas  limitações:  
1.  Não  inclui  auten]cação:  
•  Aceita  qualquer  valor  para  FROM  por  exemplo  (ó]mo  para  
spammers);  
2.  Transfere  mensagens  ASCII,  e  não  dados  binários:  
•  Daí  a  necessidade  do  MIME;  
•  Uso  ineficaz  da  largura  de  banda  (um  problema  para  grandes  
mensagens);  
3.  Envia  mensagens  às  claras:  
•  Não  usa  criptografia  (ruim  para  privacidade);  

•  Para  solucionar  alguns  dos  problemas  do  SMTP  foi  criado  o  


ESMTP  (Extended  SMTP).   49  

BCC361  
2014/02  
Correio    Eletrônico  

Transferência  de  mensagem  


•  Existem  dois  usos  do  SMTP:  
1.  Envio  de  correio:  
•  Etapa  1  da  arquitetura  de  e-­‐mail;  
•  Meio  pelo  qual  um  agente  do  usuário  envia  uma  mensagem  para  o  
sistema  de  e-­‐mail  de  entrega;  
2.  Transferência  entre  agentes  de  transferência  de  mensagens:  
•  Etapa  2  da  arquitetura  de  e-­‐mail;  
•  Entrega  do  e-­‐mail  do  agente  de  transferência  de  mensagem  emissor  
para  o  agente  receptor;  
•  A  entrega  final  é  feita  com  protocolos  diferentes.  

50  

BCC361  
2014/02  
Correio    Eletrônico  

Entrega  Minal  
•  A  úl]ma  etapa  na  arquitetura  de  e-­‐mail  trata-­‐se  da  entrega  do  
e-­‐mail  ao  agente  do  usuário;  

•  Os  usuários  desejam  acessar  seus  e-­‐mails  remotamente,  onde  


e  quando  isso  for  necessário:  
•  No  trabalho,  em  casa,  no  quarto  de  um  hotel,  LAN  House,  etc...;  
•  De  um  PC,  notebook,  celular,  etc...;  
•  Também  podem  desejar  trabalhar  off-­‐line,  sincronizando  com  o  
servidor  quando  es]ver  novamente  on-­‐line;  

•  O  SMTP  não  foi  projetado  para  estes  obje]vos,  para  isso  são  
u]lizados  outros  protocolos.   51  

BCC361  
2014/02  
Correio    Eletrônico  

Entrega  Minal  
•  Um  dos  principais  protocolos  usados  para  este  fim  é  o  IMAP  
(Internet  Message  Access  Protocol);  

•  O  cliente  IMAP  se  conecta  ao  servidor  IMAP  e  inicia  a  


execução  de  uma  série  de  comandos:  
•  Organização  das  mensagens  em  pastas;  
•  Listagem  de  pastas  e  mensagens;  
•  Buscar  mensagens  ou  parte  delas;  

•  O  IMAP  é  uma  melhoria  de  um  protocolo  mais  an]go,  o  POP3  


(Post  Office  Protocol,  version  3),  especificado  na  RFC  1939:  
•  POP3  é  mais  simples  e  fornece  menos  recursos  e  segurança;  
•  Normalmente  o  e-­‐mail  é  baixado  no  computador  do  agente  de   52  
usuário  e  deletado  do  servidor.  
BCC361  
2014/02  
Correio    Eletrônico  

Entrega  Minal  
•  Existem  também  protocolos  fechados,  como  o  MicrosoG  
Exchange;  

•  Outra  alterna]va  para  a  entrega  final  é  o  uso  de  Webmail:  


•  Trata-­‐se  de  um  so{ware  fornecido  com  um  serviço  de  uso  da  
Web;  
•  Usuários  podem  u]lizar  qualquer  navegador  que  desejarem,  em  
qualquer  máquina  conectada  na  Internet,  para  acessar  e  enviar  
mensagens;  
•  Exemplos:  Google  Gmail,  MicrosoA  Hotmail  e  Yahoo!  Mail;  
•  Normalmente  estes  serviços  fornecem  opções  de  servidores  
IMAP  e  POP3  para  possibilitar  aos  usuários  o  acesso  aos  e-­‐mails  a  
par]r  de  outras  aplicações.   53  

BCC361  
2014/02  
Introdução;  
DNS  (Domain  Name  System);  
Correio  Eletrônico;  
A  World  Wide  Web  (WWW).  

A  WORLD  WIDE  WEB  (WWW)   54  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Tópicos  
•  Introdução;  
•  Arquitetura;  
•  Páginas  está]cas;  
•  Páginas  dinâmicas;  
•  Protocolo  de  transferência.  

55  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Introdução  
•  A  World  Wide  Web,  ou  WWW,  ou  Web,  é  uma  estrutura  que  
permite  o  acesso  a  documentos  vinculados  espalhados  por  
milhões  de  máquinas  na  Internet;  

•  Sua  enorme  popularidade  se  deve,  principalmente,  a  dois  


fatores:  
•  Interface  gráfica  colorida  e  de  fácil  u]lização  para  principiantes;  
•  Uma  imensa  variedade  de  informações  sobre  quase  todos  os  
assuntos  imagináveis;  

•  Teve  seu  início  em  1989  no  CERN  (European  OrganizaEon  for  
Nuclear  Research),  para  ajudar  grandes  equipes  de  membros  
espalhados  por  vários  países  a  colaborar  compar]lhando  
56  
relatórios,  plantas,  desenhos,  fotos  e  outros  documentos.  
BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Introdução  
•  A  proposta  para  uma  teia  de  documentos  interligados  veio  do  
|sico  Tim  Berners-­‐Lee;  

•  O  primeiro  protó]po  foi  apresentado  em  1991,  chamando  a  


atenção  de  muitos  pesquisadores;  

•  Em  1993,  Marc  Andressen,  da  Universidade  de  Illinois  lançou  


um  navegador  chamado  Mosaic;  

•  Um  ano  depois  ele  formava  sua  empresa,  a  Netscape  


Communica>ons  Corp.,  que  “lutou”  durante  alguns  anos  
contra  a  MicrosoG  e  seu  navegador,  o  Internet  Explorer.   57  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Introdução  
•  No  decorrer  das  décadas  de  1990  e  2000,  sites  e  páginas  Web  
cresceram  exponencialmente,  a]ngindo  milhões  de  sites  e  
bilhões  de  páginas;  

•  Algumas  delas  se  tornaram  tremendamente  populares:  


•  Amazon,  1994,  mercado  de  US$  50  bilhões;  
•  eBay,  1995,  US$  30  bilhões;  
•  Google,  1998,  US$  150  bilhões;  
•  Facebook,  2004,  US$  15  bilhões;  

•  Em  1994,  o  CERN  e  o  MIT  criaram  o  W3C  (World  Wide  Web  


Consor>um),  www.w3.org  ou  www.w3c.br,  uma  organização  
responsável  por  organizar  e  padronizar  o  desenvolvimento   58  
Web.  
BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  (1/5)  

•  Usuário  acessando  a  página  da  Universidade  de  Washington  através  


de  um  browser  (navegador);   59  
•  Esta  página  contém  elementos  de  mídias  variadas  e  links  para  outras  
páginas;   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  (2/5)  

•  Quando  um  link  é  clicado  o  navegador  busca  a  nova  página  e  faz  a  


sua  exibição;   60  
•  Seu  conteúdo  pode  estar  na  mesma  máquina  da  página  anterior,  
mas  também  pode  não  estar,  isso  é  transparente  para  o  usuário;   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  (3/5)  

•  Cada  página  é  ob]da  enviando  solicitações  a  um  ou  mais  servidores,  


que  respondem  com  o  conteúdo  da  página;   61  
•  O  protocolo  usado  é  simples,  implementado  sobre  o  TCP,  é  
denominado  HTTP  (HyperText  Transfer  Protocol);   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  (4/5)  

•  As  páginas  podem  ser  está]cas,  ou  seja,  exibem  sempre  o  mesmo  


conteúdo;   62  
•  Ou  podem  ser  dinâmicas,  ou  seja,  o  conteúdo  é  formado  sob  
demanda,  gerada  por  um  programa;   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  (5/5)  

•  Na  figura,  o  navegador  contata  três  servidores  para  montar  as  


páginas,  cs.washington.edu  fornece  o  conteúdo  principal,   63  
youtube.com  um  conteúdo  de  vídeo,  e  google-­‐anay]cs.com  não  
fornece  dados  visíveis  ao  usuário,  mas  é  usado  para  esta~s]cas.   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  
•  Atualmente  o  site  da  Universidade  de  Washington  é  assim:  

64  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  
•  O  lado  cliente  (1/3):  
•  Para  iden]ficar  uma  página  é  u]lizada  a  URL  (Uniform  Resource  
Locator),  que  é  definido  por  três  partes:  
•  O  protocolo  (também  conhecido  como  esquema);  
•  O  nome  DNS  da  máquina  onde  está  localizada;  
•  O  caminho,  que  especifica  exclusivamente  onde  está  a  página;  

65  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  
•  O  lado  cliente  (2/3):  
•  Exemplo  de  URL:  hYp://www.cs.washington.edu/index.html;  
•  O  navegador  realiza  uma  série  de  tarefas  para  exibir  a  URL:  
1.  Obtém  o  IP  do  servidor  solicitando  ao  DNS  o  endereço  de  
www.cs.washington.edu;  
2.  Estabelece  uma  conexão  TCP  com  o  servidor  na  porta  80;  
3.  Solicita  a  página  index.html  usando  um  comando  HTTP;  
4.  Caso  a  página  incluir  links  para  outros  recursos  para  exibição  
(URLs),  buscará  estes  recursos  da  mesma  maneira;  
5.  Exibe  a  página;  
6.  Encerra  a  conexão  após  um  tempo.  

66  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  
•  O  lado  cliente  (3/3):  
•  Diferentes  protocolos  que  podem  ser  usados  em  uma  URL:  
Nome   Usado  para   Exemplo  
hnp   Hipertexto  (HTML).   hnp://www.decom.ufop.br/reinaldo  
hnps   Hipertexto  com  segurança.   hnps://www.bank.com/accounts/  
{p   FTP.   {p://{p.cs.vu.nl/pub/minix/README  
file   Arquivo  local.   file://usr/suzana/prog.c  
mailto   Envio  de  e-­‐mail.   mailto:[email protected]  
rtsp   Streaming  de  mídia.   rtsp://youtube.com/montypython.mpg  

67  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  
•  O  lado  servidor:  
•  Arquitetura  de  um  servidor  Web:  

•  Tarefas:  
•  Aceitar  uma  conexão  TCP  de  um  cliente  (um  navegador);  
•  Obter  o  caminho  até  a  página  (ou  programa);  
•  Obter  o  arquivo  (ou  gerar  o  conteúdo  dinâmico);   68  
•  Enviar  o  conteúdo  ao  cliente;  
•  Encerrar  a  conexão.   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  
•  Cookies  (1/2):  
•  Em  algumas  aplicações  é  necessário  iden]ficar  certas  
informações  do  usuário  para  personalizar  conteúdo;  
•  Exemplo:  produtos  em  uma  cesta  de  compras  de  um  site  comercial;  

•  Este  problema  é  resolvido  com  um  mecanismo  chamado  cookie,  


que  trata-­‐se  apenas  de  uma  string  pequena  contendo  algumas  
informações;  

•  Quando  o  cliente  solicita  uma  página,  o  servidor  pode  fornecer  


informações  adicionais,  na  forma  de  um  cookie  junto  com  a  
página  retornada;  
69  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Arquitetura  
•  Cookies  (2/2):  
•  O  cookie  é  armazenado  no  cliente  para  ser  u]lizado  em  novas  
requisições  ao  mesmo  servidor;  

•  Um  cookie  pode  conter  até  cinco  campos,  alguns  exemplos  de  


cookies:  
Domínio   Caminho   Conteúdo   Expira   Seguro  
toms-­‐casino.com   /   CustomerI=D297793521   15-­‐0-­‐10-­‐17:00   Sim  
jiils-­‐store.com   /   Cart=1-­‐00501;1-­‐07031   11-­‐1-­‐11  14:22   Não  
aportal.com   /   Prefs=Stk;CSCO   31-­‐12-­‐20  23:50   Não  
sneaky.com   /   UserId=4627239101   31-­‐12-­‐19  23:59   Não  
70  
•  Cookies  estão  envolvidos  com  algumas  questões  de  privacidade  e  
segurança,  muitos  gostam  de  desa]var  o  seu  uso  no  navegador.   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  estáticas  
•  Forma  mais  simples  de  página  Web,  elas  são  armazenadas  em  
um  servidor,  que  as  retorna  para  serem  diretamente  exibidas  
no  browser  quando  solicitadas;  

•  Normalmente  as  páginas  está]cas  são  desenvolvidas  em  


linguagem  HTML  (HyperText  Markup  Language):  
•  Linguagem  de  marcação  que  u]liza  tags  para  determinar  a  
estrutura  e  formatação  do  conteúdo;  
•  Exemplos  de  tags:  
•  <b>  negrito  </b>;  
•  <img>  ...  </img>  para  inserir  imagem;  
•  <body>  ...  </body>  para  determinar  o  conteúdo  da  página;  
71  
•  <a>  ...  </a>  para  definir  hiperlinks.  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  estáticas  
•  A  HTML  já  passou  por  várias  evoluções:  
Item   HTML  1.0   HTML  2.0   HTML  3.0   HTML  4.0   HTML  5.0  
Hiperlinks   X   X   X   X   X  
Imagens  e  listas   X   X   X   X   X  
Mapas  e  imagens  a]vas   X   X   X   X  
Formulários   X   X   X   X  
Equações   X   X   X  
Barras  de  ferramentas   X   X   X  
Tabelas   X   X   X  
Recursos  de  acessibilidade   X   X  
Objetos  inseridos   X   X  
Folhas  de  es]lo   X   X  
ScripEng   X   X  
Vídeo  e  áudio   X  
Gráficos  e  vetores  em  linha   X  
Representação  XML   X  
Threads  em  segundo  plano   X  
72  
Armazenamento  pelo  navegador   X  
Tela  de  desenho   X   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  estáticas  
•  O  obje]vo  original  do  HTML  era  de  apenas  estruturar  as  
páginas:  
•  A  formatação  ficaria  a  cargo  dos  navegadores;  
•  No  entanto,  desenvolvedores  queriam  alterar  formatação,  e  
vários  recursos  de  formatação  foram  inseridos;  

•  Estes  recursos  levaram  a  alguns  incômodos:  


•  Poluição  do  código  HTML;  
•  Problema  de  portabilidade.  

73  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  estáticas  
•  Para  resolver  os  problemas  de  formatação  foi  criado  o  
conceito  de  folha  de  es]lo,  o  CSS  (Cascade  Style  Sheets),  que  
faz  a  separação  do  código  estrutural  (HTML)  do  código  de  
formatação  (CSS);  

•  Existem  outros  recursos  para  páginas  está]cas,  como  o  Flash  


por  exemplo;  

•  Note  que  vídeo,  animações,  ou  outras  mídias,  não  são  


suficientes  para  classificar  uma  página  como  dinâmica.  

74  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  dinâmicas  
•  O  modelo  de  páginas  está]cas  foi  ú]l  nos  primeiros  
momentos  da  Web,  quando  um  grande  volume  de  informação  
foi  inserido;  

•  Atualmente,  grande  parte  do  uso  da  Web  está  voltado  para  
aplicações  e  serviços:  
•  Comércio  eletrônico;  
•  Pesquisa  em  catálogos  de  bibliotecas  ou  na  própria  Web;  
•  Leitura  e  envio  de  e-­‐mails;  
•  Colaboração  e  redes  sociais;  

•  Neste  novo  modelo,  as  páginas  são  construídas  


dinamicamente,  com  base  em  dados  fornecidos  pelos   75  
usuários.  
BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  dinâmicas  
•  Geração  de  páginas  dinâmicas:  

•  Pode  ocorrer  no  lado  do  cliente  (navegador);  


•  Ou  no  lado  servidor.  

76  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  dinâmicas  
•  APIs  para  páginas  dinâmicas  do  lado  SERVIDOR  (1/2):  
•  CGI  (Common  Gateway  Interface):  
•  Definido  na  RFC  3875;  
•  Oferece  uma  interface  para  permi]r  que  os  servidores  “falem”  com  
programas  de  back-­‐end  e  scripts  que  aceitam  entrada  (formulários  
por  exemplo)  e  gerem  páginas  em  resposta;  
•  Os  programas  podem  ser  escritos  em  variadas  linguagens:  Python,  
Ruby,  Perl,  etc...;  

77  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  dinâmicas  
•  APIs  para  páginas  dinâmicas  do  lado  SERVIDOR  (2/2):  
•  PHP  (Hypertext  Preprocessor):  
•  A  técnica  consiste  em  inserir  código  script  dentro  das  páginas  HTML;  
•  Os  scripts  serão  executados  no  próprio  servidor,  originando  uma  
página  HTML  como  resultado;  
•  PHP  é  uma  linguagem  de  programação  poderosa  para  a  interface  
entre  a  Web  e  bancos  de  dados  do  servidor;  
•  Ela  contém  variáveis,  strings,  arrays  e  a  maior  parte  das  estruturas  
de  controle  encontradas  no  C;  
•  JSP  (Java  Server  Pages):  
•  Semelhante  ao  PHP,  mas  u]liza  linguagem  Java;  
•  ASP.NET  (Ac>ve  Server  Pages  .NET):  
•  Versão  da  Microso{  para  PHP  e  JSP.   78  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  dinâmicas  
•  Páginas  dinâmicas  do  lado  CLIENTE  (1/2):  
•  Para  responder  a  movimentos  do  mouse  ou  interagir  diretamente  
com  os  usuários  é  necessário  incorporar  scripts  em  páginas  HTML  
executadas  na  máquina  cliente;  

•  A  par]r  do  HTML  4.0  esses  scripts  são  permi]dos,  através  do  uso  
da  tag  <script>;  

•  A  linguagem  mais  popular  é  a  JavaScript  (nenhuma  relação  com  a  


linguagem  Java,  além  do  nome);  

79  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  dinâmicas  
•  Páginas  dinâmicas  do  lado  CLIENTE  (2/2):  
•  Uma  alterna]va  ao  JavaScript,  na  plataforma  Windows  é  o  
VBScript,  que  é  baseado  no  Visual  Basic;  

•  Outro  método  popular  é  os  applets,  que  são  pequenos  


programas  escritos  em  Java  (incorporados  a  par]r  da  tag  
<applet>);  

•  Uma  solução  da  MicrosoA  semelhante  aos  applets  é  denominada  


de  controles  Ac>veX,  que  são  programas  compilados  na  
linguagem  de  máquina  X86  e  executados  no  hardware  bruto.  

80  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  dinâmicas  
•  AJAX  (Asynchronous  JavaScript  and  XML)  (1/2):  
•  Trata-­‐se  de  um  conjunto  de  tecnologias  que  trabalham  juntas  
para  criar  aplicações  Web  tão  intera]vas  e  poderosas  quanto  
aplicações  de  desktop  tradicionais;  

•  O  AJAX  possibilita  que  páginas  Web  sejam  atualizadas  


assincronamente  através  da  troca  de  pequenas  quan]dades  de  
dados  com  seus  servidores;  
•  Isto  possibilita  que  apenas  partes  da  página  sejam  atualizadas,  sem  a  
necessidade  de  recarregar  todo  o  conteúdo  da  página;  

81  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Páginas  dinâmicas  
•  AJAX  (Asynchronous  JavaScript  and  XML)  (2/2):  
•  Tecnologias  envolvidas:  
1.  HTML  e  CSS:  para  apresentar  as  informações  como  páginas;  
2.  DOM  (Document  Object  Model):  árvore  que  reflete  a  estrutura  dos  
elementos  HTML,  u]lizado  para  alterar  partes  da  página  quando  
elas  são  exibidas;  
3.  XML  (eXtensible  Markup  Language):  para  permi]r  a  troca  de  dados  
entre  cliente  e  servidor;  
4.  Um  modo  assíncrono  para  os  programas  enviarem  e  receberem  
dados  XML;  
5.  JavaScript:  como  uma  linguagem  para  juntar  toda  esta  
funcionalidade;  
 
82  
•  Exemplos  de  páginas  que  usam  AJAX:  Gmail,  Maps  e  Docs  da  
Google,  Youtube  e  Facebook.   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Protocolo  de  transferência  


•  O  protocolo  u]lizado  para  transportar  toda  a  informação  
entre  os  servidores  Web  e  os  clientes  Web  é  o  HTTP  
(HyperText  Transfer  Protocol),  especificado  na  RFC  2116;  

•  HTTP  é  um  protocolo  simples:  


•  Funciona  no  es]lo  solicitação-­‐resposta,  rodando  sobre  o  TCP;  
•  Especifica  quais  mensagens  os  clientes  podem  enviar  para  os  
servidores  e  quais  respostas  recebem  de  volta;  
•  Assim  como  no  SMTP,  os  cabeçalhos  são  dados  em  ASCII  e  o  
conteúdo  é  dado  em  formato  ]po  MIME;  

•  Parte  do  sucesso  da  Web  é  creditado  à  simplicidade  do  HTTP,   83  


que  facilitou  o  seu  desenvolvimento  e  implantação.  
BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Protocolo  de  transferência  


•  Conexões:  
•  U]liza  protocolo  TCP  na  porta  80;  
•  Conexões  são  persistentes;  
•  Os  dados  podem  ser  requisitados  em  pipeline;  
 
 
 
 
 
 
 
 
 
 
  84  
(a) múltiplas conexões e solicitações sequenciais.
(b) Conexão persistente e solicitações sequenciais.
(c) Conexão persistente com solicitações em pipeline   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Protocolo  de  transferência  


•  Métodos:  
•  O  HTTP  aceita  operações  chamadas  métodos;  
•  Cada  solicitação  consiste  de  uma  ou  mais  linhas  de  texto  ASCII,  sendo  a  
primeira  palavra  da  primeira  linha  o  método  solicitado:  
Método   Descrição  
GET   Lê  uma  página  Web.  
Lê  um  cabeçalho  de  página  Web.  Pode  ser  usado  para  indexação  ou  testar  a  
HEAD  
validade  de  um  URL.  
Acrescenta  algo  a  uma  página  Web.  Usado  para  envio  de  dados  de  formulários  
POST  
para  o  servidor.  
Armazena  uma  página  Web.  É  o  contrário  de  GET,  possibilita  criar  uma  coleção  
PUT  
de  páginas  Web  em  um  servidor  remoto.  
DELETE   Remove  a  página  Web.  
Ecoa  a  solicitação  recebida.  Serve  para  depuração,  envia  o  servidor  a  enviar  de  
TRACE  
volta  a  solicitação  para  saber  qual  solicitação  o  servidor  recebeu  de  fato.   85  
CONNECT   Conecta  através  de  um  proxy.  
Consulta  opções  para  uma  página.  Possibilita  descobrir  quais  são  os  métodos  e  
OPTIONS   BCC361  
cabeçalhos  que  podem  ser  usados  com  uma  página.   2014/02  
A  World  Wide  Web  (WWW)  

Protocolo  de  transferência  


•  Códigos  de  erro:  
•  Toda  solicitação  obtém  uma  resposta  que  possui  uma  linha  de  
status,  com  um  código  de  três  dígitos  informando  se  a  solicitação  
foi  atendida  ou  qual  foi  o  erro:  
Código   Significado   Exemplos  
1xx   Informação   100  =  servidor  concorda  em  tratar  da  solicitação  do  cliente.  
200  =  solicitação  com  sucesso;    
2xx   Sucesso  
204  =  nenhum  conteúdo  presente.  
301  =  página  movida;  
3xx   Redirecionamento  
304  =  página  em  cache  ainda  válida.  
403  =  página  proibida;  
4xx   Erro  do  cliente  
404  =  página  não  localizada.  
500  =  erro  interno  do  servidor;  
5xx   Erro  do  servidor  
503  =  tente  novamente  mais  tarde.  
86  

BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Protocolo  de  transferência  


•  Cabeçalhos  de  mensagens:  
•  Toda  solicitação  pode  ser  seguida  de  linhas  adicionais  contendo  
mais  informações,  chamadas  de  cabeçalhos  de  solicitação;  
•  De  forma  análoga,  as  respostas  podem  ser  seguidas  de  linhas  
denominadas  cabeçalhos  de  resposta;  
•  Alguns  possíveis  cabeçalhos  (a  lista  é  extensa):  
Cabeçalho   Tipo   Conteúdo  
User-­‐Agent   Solicitação   Informações  sobre  o  navegador  e  sua  plataforma.  
Accept   Solicitação   O  ]po  de  páginas  que  o  cliente  pode  manipular.  
Accept-­‐Charset   Solicitação   Os  conjuntos  de  caracteres  aceitáveis  para  o  cliente.  
Accept-­‐Encoding   Solicitação   As  codificações  de  páginas  que  o  cliente  pode  manipular.  
Cookie   Solicitação   Cookie  previamente  definido,  enviado  de  volta  ao  servidor.  
Set-­‐Cookie   Resposta   Cookie  para  ser  armazenado  no  cliente.  
Expires   Resposta   Data  e  hora  de  quando  a  página  deixa  de  ser  válida.   87  
Last-­‐Modified   Resposta   Data  e  hora  da  úl]ma  modificação  da  página.  
Cache-­‐Control   Ambos   Dire]vas  para  o  modo  de  tratar  caches.   BCC361  
2014/02  
A  World  Wide  Web  (WWW)  

Protocolo  de  transferência  


•  Caching:  
•  Normalmente  os  usuários  retornam  às  páginas  visitadas  com  
frequência;  
•  Muitos  recursos  u]lizados  nunca  mudam,  ou  mudam  pouco,  seria  
um  desperdício  capturar  todos  eles  toda  vez  que  uma  página  
fosse  novamente  solicitada;  
•  O  HTTP  usa  duas  estratégias  para  enfrentar  este  problema:  

88  

BCC361  
2014/02  
Fim!  
REFERÊNCIAS:  
•  A.S.  TANENBAUM,  Redes  de  Computadores,  Pren]ce  Hall,  
5a.  edição,  2011;  
•  KUROSE  e  ROSS,  Redes  de  Computadores  e  a  Internet  –  uma  
abordagem  top-­‐down,  5a.  Edição,  2010.  
•  Materiais  didá]cos  dos  professores:  
•  Rande  A.  Moreira,  UFOP  /  2011-­‐01    
Disponível  em:  hnp://randearievilo.com.br/redes/  (acesso  em  17/08/2011);  

89  

BCC361  
2014/02  

Você também pode gostar