A apresentação está carregando. Por favor, espere

A apresentação está carregando. Por favor, espere

Introdução à Arquitectura de aplicações para a Web.

Apresentações semelhantes


Apresentação em tema: "Introdução à Arquitectura de aplicações para a Web."— Transcrição da apresentação:

1 Introdução à Arquitectura de aplicações para a Web

2 Arquitectura Cliente, Servidor Protocolo de comunicação HTTP Noção de URL Evolução histórica Desenvolvimentos actuais

3 Arquitectura Cliente Servidor ClienteServidor xpto

4 Protocolo HTTP HTTP – Hypertext Transfer Protocol Protocolo de comunicação baseado no TCP/IP. Especificação W3C (http://www.w3.org/Protocols/) Suporta a transferencia de informação entre o cliente e o servidor Web. Métodos GET e POST Stateless - Cookies

5 HTTP Request GET /index.html HTTP/1.1 Host: HTTP/ OK Response Date: Mon, 23 May :38:34 GMT Server: Apache/ (Unix) (Red-Hat/Linux) Last-Modified: Wed, 08 Jan :11:55 GMT Etag: "3f80f-1b6-3e1cb03b" Accept-Ranges: bytes Content-Length: 438 Connection: close Content-Type: text/html; charset=UTF-8

6 HTTP Request

7 HTTP Response

8 HTTP Status Code Format Status Code Format MeaningDescription 1yy Informational Message Provides general information; does not indicate success or failure of a request. 2yySuccess The method was received, understood and accepted by the server. server 3yyRedirection The request did not fail outright, but additional action is needed before it can be successfully completed. 4yyClient Error The request was invalid, contained bad syntax or could not be completed for some other reason that the server believes was the client's fault. 5yyServer Error The request was valid but the server was unable to complete it due to a problem of its own.

9 Servidor Web Aplicação informática que trata os pedidos HTTP dos clientes Web. Servidores mais usuais IIS – Internet Information Server Mais usual no universo Windows Desenvolvido pela Microsoft Apache Usual nos sistemas Unix/Linux Também existe para sistemas Windows Open Source

10 Noção de URL URL – Uniform Resource Location Sintaxe Exemplos: ftp://ftp.dei.isep.ipp.pt gopher://gopher.micro.umn.edu/11 wais://cnidr.org/directory-of-servers protocolo://endereco/caminho/nomeFicheiro

11 Evolução histórica 1. Páginas simplesmente estáticas O servidor Web é simplesmente um repositório de páginas (ficheiros HTML) que são enviados para o cliente ao seu pedido. A informação e o aspecto da página será constante ao longo do tempo. Mudando unicamente se houver intervenção do programador.

12 Evolução histórica 2. Paginas estáticas com scripts embutidos Continuam a ser páginas estáticas São introduzidos objectos dinâmicos na página recorrendo a uma linguagem de script. Estes scripts são interpretados e executados no browser cliente. Suportadas pelo IE 3+ e pelo Netscape 4+ As linguagens de script mais usuais são JavaScript VBScript

13 Evolução histórica 3. Paginas dinâmicas O servidor constrói a página que será enviada ao cliente. Permite interacção com recursos externos (p.e. Bases de Dados) O aspecto e a informação da página obtida pelo cliente depende de parâmetros que foram passados ao servidor a quando do pedido

14 Evolução histórica Páginas dinâmicas Cliente Servidor Recursos externos

15 Evolução histórica 4. Paginas dinâmicas com CGI CGI – Common Gateway Interface. Existe uma aplicação no servidor (aplicação CGI) que será invocada pelo pedido do cliente e que irá construir em tempo real a página que será enviada ao cliente. As aplicações CGI podem ser programadas em qualquer linguagem que aceda ao STDIN e ao STDOUT. As mais usuais são: Perl C

16 Exemplo de um CGI /*************************************************************************/ /** **/ /** hello_s.c -- "hello, world" simple, para demonstrar a **/ /** saida CGI basica. **/ /** **/ /*************************************************************************/ #include void main() { /** Imprimir o header de resposta CGI, exigido para toda saida HTML. **/ /** Notar o \n adicional, para enviar a linha vazia. **/ printf("Content-type: text/html\n\n") ; /** Imprimir a pagina de resposta HTML em STDOUT. **/ printf(" \n") ; printf(" CGI Output \n") ; printf(" \n") ; printf(" Hello, world. \n") ; printf(" \n") ; printf(" \n") ; exit(0) ; }

17 Evolução histórica 5. Páginas dinâmicas com código embutido O código da linguagem utilizado para a geração da página coexiste com os comandos HTML que formatam a página. São mais simples de desenvolver e de manter que as aplicações CGI. As tecnologias mais usuais desta categoria são: ASP PHP JSP

18 Exemplo de uma página ASP Your name: "" Then Response.Write("Hello " & fname & "! ") Response.Write("How are you today?") End If %>

19 Exemplo de uma página ASP You can use HTML tags to format the text! ") %> This text is styled with the style attribute! ") %>

20 Exemplo de PHP Form Name: Age: welcome.php Welcome. You are years old.

21 Exemplo de PHP

22 Evolução histórica 6. Páginas ASP.NET Beneficia da tecnologia.NET Independente do browser cliente Informação inserida no cliente é directamente processada no servidor (conceito de Web Form) O código utilizado para a construção da página e o código que define a interface podem ser colocados em ficheiros disjuntos (programação code-behind)

23 WWW The great need for information about information, to help us categorize, sort, pay for, own information is driving the design of languages for the web designed for processing by machines, rather than people. The web of human-readable document is being merged with a web of machine-understandable data. The potential of the mixture of humans and machines working together and communicating through the web could be immense. Tim Berners-Lee

24 Q: You talked about the need for a metadata language. Can you tell us laymen what it is? A: "Meta" is used with anything which is about itself (...) metadata is data about data. On the Web, this means all sorts of information about information(...)These needs are driving us to make ways of putting information on the web designed for computers to be able to understand. Web pages at the moment in HTML are designed to be read by humans. In the future, some Web pages will be in "RDF" -- Resource Description Framework. This will be read by computer programs which will help us organize ourselves and our data and possibly everything we do.

25 WWW The Semantic Web provides a common framework that allows data to be shared and reused across application, enterprise, and community boundaries. It is a collaborative effort led by W3C with participation from a large number of researchers and industrial partners. It is based on the Resource Description Framework (RDF).RDF The Semantic Web is a web of data

26 WWW Web Ontology Language WEB 2.0 Inteligência colectiva Trabalho colaborativo Conhecimento distribuído AJAX Assynchronous JavaScript Aplicações Web mais interactivas

27


Carregar ppt "Introdução à Arquitectura de aplicações para a Web."

Apresentações semelhantes


Anúncios Google