SlideShare una empresa de Scribd logo
1 de 26
Programación Web

Desarrollo de aplicaciones Web
Arquitectura de las aplicaciones Web.
Arquitectura de dos niveles:
Es la más simple, se tiene el nivel del “Cliente” y el nivel del “Servidor”.
Arquitectura Web de tres niveles:
•   El primer nivel consiste en la capa de presentación que incluye no sólo el
    navegador, sino también el servidor web que es el responsable de dar a los
    datos un formato adecuado. El segundo nivel está referido habitualmente a
    algún tipo de programa o script. Finalmente, el tercer nivel proporciona al
    segundo los datos necesarios para su ejecución.
Lenguajes de programación del lado del
                  cliente.
• Los programas del lado del cliente están
  incluidos dentro de la página HTML, se
  descargan del servidor junto con este.
• Los programas se ejecutan dentro del ámbito
  del browser.
Tecnologías y lenguajes del lado del cliente.
– Navegadores para Web.
– HTML.
– Javascript y Vbscript.
– Applets en Java.
– Flash (lenguaje ActionScript).
– XML.
– PDF.
– AJAX, acrónimo de Asynchronous JavaScript And
  XML (JavaScript asíncrono y XML).
Lenguajes del lado del cliente
•   Algunos navegadores Web.
     –   Amaya
     –   Epiphany
     –   Galeon
     –   Internet Explorer
     –   Konqueror
     –   Lynx
     –   Mozilla suite navigator
     –   Mozilla Firefox
     –   Netscape Navigator
     –   Opera
     –   Safari
     –   Shiira
     –   Maik Navigator
Tecnologías y lenguajes del lado del cliente.


• Algunos de estos lenguajes y tecnologías requieren de un
  programa especial (plug-in) instalado en la computadora
  del usuario. Ejemplo: Adobe Flash Player.

• Un complemento (o plug-in en inglés) es una aplicación
  que se relaciona con otra para aportarle una función
  nueva y generalmente muy especifica. Esta aplicación
  adicional es ejecutada por la aplicación principal e
  interactúan por medio de la API.
Lenguajes de programación del lado del
                    servidor.
• Se ejecutan en el servidor de Web y son dependientes de la
  plataforma del servidor.




•   Se usan para acceder a recursos del servidor, como bases de datos y
    generación de contenido dinámico para las páginas.
Lenguajes de programación del lado del
                  servidor.
• Por ejemplo, el ámbito de ejecución de una
  página ASP.NET.
Lenguajes de programación del lado del
                   servidor.
Algunos ejemplos de lenguajes del lado del servidor:

• ASP, ASP.NET (son tecnologías, soportan diferentes lenguajes como
  VB, C#, C++, etc.).
• PHP.
• JSP.
• Perl.
• Ruby.
• Python.
• XML.
Servidor Web
• Un servidor web es un programa que implementa el
  protocolo HTTP ). Este protocolo pertenece a la capa de
  aplicación del modelo OSI y está diseñado para transferir
  lo que se llama hipertextos, páginas web o páginas
  HTML: textos complejos con enlaces, figuras,
  formularios, botones y objetos incrustados como
  animaciones o reproductores de música.
Servidor Web.
• Algunos ejemplos:
   – CERN httpd
   – Apache (Libre, servidor más usado del mundo, según Wikipedia)
   – IIS
   – Resin
   – Tomcat(Libre, del proyecto Jakarta de Apache)
   – Geronimo(Libre, orientado a J2EE, del proyecto Jakarta de Apache,
     actualmente se encuentra en desarrollo)
   – JBoss
   – JOnAS
   – Cherokee
Ambientes para el desarrollo de aplicaciones
                   Web.
• Los IDE (ambientes integrados de desarrollo) para
  aplicaciones Web son muy numerosos.
• Considerar los que permitan trabajar con los diferentes
  lenguajes para Web.
• Algunos son específicos para lenguajes del lado del
  servidor. Por ejemplo, Visual Studio solo soporta
  ASP.NET del lado del servidor.
• Existen IDE’s de buena cantidad, libres y gratuitos de
  buena calidad.
Ambientes para el desarrollo de aplicaciones
                   Web.

• Algunos ejemplos de IDE para Web:
  –   Microsoft Visual Studio.
  –   Microsoft Web Developer Express.
  –   Mono (para ASP.NET).
  –   NetBeans.
  –   Jbuilder.
  –   Eclipse.
Metodologías para el desarrollo de
                aplicaciones Web.
• Ciclo de vida clásico. Pressman, “adapta” esta
  metodología para el desarrollo de Web, en lo que el
  llama la “Ingeniería Web”:
   –   Formulación.
   –   Planificación.
   –   Análisis (contenido, interacción, funcional, configuración).
   –   Diseño (arquitectónico, navegación, interfaz, de base de datos).
   –   Implementación.
   –   Pruebas.
Metodologías para el desarrollo de
             aplicaciones Web.

• UWE UML (UML-Based Web Engineering) es
  una metodología de desarrollo de aplicaciones
  web, utilizada en la ingeniería web, prestando
  especial atención en sistematización y
  personalización (sistemas adaptativos).
UWE UML
El método UWE UML consta de seis modelos:

• Modelo de casos de uso para capturar los requisitos del sistema.
• Modelo conceptual para el contenido (modelo del dominio).
• Modelo de usuario: modelo de navegación que incluye modelos estáticos
  y dinámicos.
• Modelo de estructura de presentación, modelo de flujo de presentación.
• Modelo abstracto de interfaz de usuario y modelo de ciclo de vida del
  objeto.
• Modelo de adaptación.
Aspectos de seguridad.
• Las aplicaciones Web están más expuestas a
  ataques.

Se pueden tener ataques en tres niveles:
  – A la computadora del usuario.
  – Al servidor.
  – A la información en tránsito.
La seguridad en Web tiene 3 etapas primarias:
– Seguridad de la computadora del usuario.
– Seguridad del servidor Web y de los datos
  almacenados ahí.
– Seguridad de la información que viaja entre el
  servidor Web y el usuario.
Seguridad de la computadora del usuario

• Los usuarios deben contar con navegadores y
  plataformas seguras, libres de virus y
  vulnerabilidades. También debe garantizarse
  la privacidad de los datos del usuario.
Seguridad del servidor Web y de los datos
  almacenados ahí
• Se debe garantizar la operación continua del
  servidor, que los datos no sean modificados
  sin autorización (integridad) y que la
  información sólo sea distribuida a las personas
  autorizadas (control de acceso).
• Seguridad de la información que viaja entre el
  servidor Web y el usuario.

Garantizar que la información en tránsito no sea leída
  (confidencialidad), modificada o destruida por terceros.
  También es importante asegurar que el enlace entre
  cliente y servidor no pueda interrumpirse fácilmente
  (disponibilidad).
Recomendaciones: Asegurar el servidor

Se deben considerar los siguientes puntos:
• Asegurar el servidor en una forma fundamental: el
  sistema operativo, ya sea por medio de actualizaciones
  (parches) y habilitando los mecanismos propios de la
  plataforma.
• Garantizar la seguridad del servidor Web propiamente
  (IIS, Apache, etc.)
• Auditar las aplicaciones que interactúan en las    dos
  capas anteriores (módulos, bibliotecas).
Recomendaciones: Asegurar la información
             en tránsito
 Esto se puede lograr por diversos medios:
• Asegurando la red físicamente (switches en lugar de
   hubs).
• Esconder la información (esteganografía).
• Cifrar la información (criptografía) por medio de
   algoritmos diversos (SSL, VPNs).
Recomendaciones:
           Asegurar el equipo del usuario

  Vulnerar el equipo del usuario quizás no tenga el impacto
  de vulnerar el servidor, sin embargo es un problema más
  difícil de erradicar (1 servidor, 5000 clientes):

• Aplicar actualizaciones (parches) al sistema
 operativo.
• Uso de antivirus, firewalls personales.
• Educación de los usuarios.
• GRACIAS…

Más contenido relacionado

La actualidad más candente

La actualidad más candente (17)

Arquitectura- Programacion WEB
Arquitectura- Programacion WEBArquitectura- Programacion WEB
Arquitectura- Programacion WEB
 
Tecnologias de desarrollo web
Tecnologias de desarrollo webTecnologias de desarrollo web
Tecnologias de desarrollo web
 
La importancia del frontend y backend en un proyecto
La importancia del frontend y backend en un proyectoLa importancia del frontend y backend en un proyecto
La importancia del frontend y backend en un proyecto
 
Diseño y Desarrollo Web
Diseño y Desarrollo WebDiseño y Desarrollo Web
Diseño y Desarrollo Web
 
Charla internet
Charla internetCharla internet
Charla internet
 
lenguaje web
lenguaje weblenguaje web
lenguaje web
 
Tecnologia ASP.net
Tecnologia ASP.netTecnologia ASP.net
Tecnologia ASP.net
 
Presentacion tecnica microsoft.net
Presentacion tecnica microsoft.netPresentacion tecnica microsoft.net
Presentacion tecnica microsoft.net
 
2.2 lenguajes del lado cliente
2.2 lenguajes del lado cliente2.2 lenguajes del lado cliente
2.2 lenguajes del lado cliente
 
Programacion web c5 programacion del lado servidor
Programacion web c5 programacion del lado servidorProgramacion web c5 programacion del lado servidor
Programacion web c5 programacion del lado servidor
 
Internet - Teconología para Sistemas Web
Internet - Teconología para Sistemas WebInternet - Teconología para Sistemas Web
Internet - Teconología para Sistemas Web
 
Front end y Back-end
Front end y Back-end Front end y Back-end
Front end y Back-end
 
JSP
JSPJSP
JSP
 
Tema2: Tecnologías de desarrollo web (Desarrollo Aplicaciones Web)
Tema2: Tecnologías de desarrollo web (Desarrollo Aplicaciones Web)Tema2: Tecnologías de desarrollo web (Desarrollo Aplicaciones Web)
Tema2: Tecnologías de desarrollo web (Desarrollo Aplicaciones Web)
 
Pag. web
Pag. webPag. web
Pag. web
 
introducción tecnologías web
introducción tecnologías webintroducción tecnologías web
introducción tecnologías web
 
Javascript
JavascriptJavascript
Javascript
 

Destacado

Fundamentos de Desarrollo Web
Fundamentos de Desarrollo Web Fundamentos de Desarrollo Web
Fundamentos de Desarrollo Web Alexander
 
Lenguaje de programación web
Lenguaje de programación webLenguaje de programación web
Lenguaje de programación webEduardo Alvarez
 
Fundamentos técnicos de internet
Fundamentos técnicos de internetFundamentos técnicos de internet
Fundamentos técnicos de internetJuan Álvarez
 
Programacion web introduccion practica o9
Programacion web introduccion practica o9Programacion web introduccion practica o9
Programacion web introduccion practica o9Anavay
 
Lenguajes de programación web
Lenguajes de programación webLenguajes de programación web
Lenguajes de programación webKriss Rachel
 
C) elaboracion de formularios dinamicos en paginas web mediante el uso de un ...
C) elaboracion de formularios dinamicos en paginas web mediante el uso de un ...C) elaboracion de formularios dinamicos en paginas web mediante el uso de un ...
C) elaboracion de formularios dinamicos en paginas web mediante el uso de un ...Chaarly Fiiguerooa
 
PROGRAMACIÓN WEB INTRODUCCIÓN
PROGRAMACIÓN WEB INTRODUCCIÓNPROGRAMACIÓN WEB INTRODUCCIÓN
PROGRAMACIÓN WEB INTRODUCCIÓNKarol Moreno
 

Destacado (9)

Fundamentos de Desarrollo Web
Fundamentos de Desarrollo Web Fundamentos de Desarrollo Web
Fundamentos de Desarrollo Web
 
Lenguaje de programación web
Lenguaje de programación webLenguaje de programación web
Lenguaje de programación web
 
Fundamentos técnicos de internet
Fundamentos técnicos de internetFundamentos técnicos de internet
Fundamentos técnicos de internet
 
Lenguajes de programación web
Lenguajes de programación webLenguajes de programación web
Lenguajes de programación web
 
Programacion web introduccion practica o9
Programacion web introduccion practica o9Programacion web introduccion practica o9
Programacion web introduccion practica o9
 
Lenguajes de programación web
Lenguajes de programación webLenguajes de programación web
Lenguajes de programación web
 
Programacion web
Programacion webProgramacion web
Programacion web
 
C) elaboracion de formularios dinamicos en paginas web mediante el uso de un ...
C) elaboracion de formularios dinamicos en paginas web mediante el uso de un ...C) elaboracion de formularios dinamicos en paginas web mediante el uso de un ...
C) elaboracion de formularios dinamicos en paginas web mediante el uso de un ...
 
PROGRAMACIÓN WEB INTRODUCCIÓN
PROGRAMACIÓN WEB INTRODUCCIÓNPROGRAMACIÓN WEB INTRODUCCIÓN
PROGRAMACIÓN WEB INTRODUCCIÓN
 

Similar a Programación web

Arquitectura web EXPOSICION KAREN ANDRADE, EFRAIN SARANSIG
Arquitectura web  EXPOSICION KAREN ANDRADE, EFRAIN SARANSIGArquitectura web  EXPOSICION KAREN ANDRADE, EFRAIN SARANSIG
Arquitectura web EXPOSICION KAREN ANDRADE, EFRAIN SARANSIGEfrain Criss
 
Tema1 seleccion de_arquitecturas_y_herramientas_de_programacion
Tema1 seleccion de_arquitecturas_y_herramientas_de_programacionTema1 seleccion de_arquitecturas_y_herramientas_de_programacion
Tema1 seleccion de_arquitecturas_y_herramientas_de_programacionJuana Sánchez
 
los-diferentes-lenguajes-de-programacion-para-la-web
 los-diferentes-lenguajes-de-programacion-para-la-web los-diferentes-lenguajes-de-programacion-para-la-web
los-diferentes-lenguajes-de-programacion-para-la-webolguisf
 
los diferentes lenguajes de programación para-la-web
 los diferentes lenguajes de programación para-la-web los diferentes lenguajes de programación para-la-web
los diferentes lenguajes de programación para-la-webolguisf
 
Programacion web al lado del servidor.pdf
Programacion web al lado del servidor.pdfProgramacion web al lado del servidor.pdf
Programacion web al lado del servidor.pdfJoseArevalo99
 
15-Unidad 4: Introducción a las Arquitecturas Web 4.1 DAO 4.2 MVC
15-Unidad 4: Introducción a las Arquitecturas Web 4.1 DAO 4.2 MVC15-Unidad 4: Introducción a las Arquitecturas Web 4.1 DAO 4.2 MVC
15-Unidad 4: Introducción a las Arquitecturas Web 4.1 DAO 4.2 MVCLuis Fernando Aguas Bucheli
 
2009_asp.net_capitulo_1
2009_asp.net_capitulo_12009_asp.net_capitulo_1
2009_asp.net_capitulo_1zhylz Zevallos
 

Similar a Programación web (20)

Prog webuni3
Prog webuni3Prog webuni3
Prog webuni3
 
Prog webuni3
Prog webuni3Prog webuni3
Prog webuni3
 
Web2
Web2Web2
Web2
 
UWE
UWEUWE
UWE
 
¿Cómo elegir servidor web?
¿Cómo elegir servidor web?¿Cómo elegir servidor web?
¿Cómo elegir servidor web?
 
Cómo elegir un servidor Web
Cómo elegir un servidor WebCómo elegir un servidor Web
Cómo elegir un servidor Web
 
Exposicion
ExposicionExposicion
Exposicion
 
Arquitectura web EXPOSICION KAREN ANDRADE, EFRAIN SARANSIG
Arquitectura web  EXPOSICION KAREN ANDRADE, EFRAIN SARANSIGArquitectura web  EXPOSICION KAREN ANDRADE, EFRAIN SARANSIG
Arquitectura web EXPOSICION KAREN ANDRADE, EFRAIN SARANSIG
 
Tecnologias de desarrollo web
Tecnologias de desarrollo webTecnologias de desarrollo web
Tecnologias de desarrollo web
 
Tema1 seleccion de_arquitecturas_y_herramientas_de_programacion
Tema1 seleccion de_arquitecturas_y_herramientas_de_programacionTema1 seleccion de_arquitecturas_y_herramientas_de_programacion
Tema1 seleccion de_arquitecturas_y_herramientas_de_programacion
 
Unidad 1
Unidad 1Unidad 1
Unidad 1
 
los-diferentes-lenguajes-de-programacion-para-la-web
 los-diferentes-lenguajes-de-programacion-para-la-web los-diferentes-lenguajes-de-programacion-para-la-web
los-diferentes-lenguajes-de-programacion-para-la-web
 
los diferentes lenguajes de programación para-la-web
 los diferentes lenguajes de programación para-la-web los diferentes lenguajes de programación para-la-web
los diferentes lenguajes de programación para-la-web
 
Clase 1 introd asp net
Clase 1  introd asp net Clase 1  introd asp net
Clase 1 introd asp net
 
Programacion web al lado del servidor.pdf
Programacion web al lado del servidor.pdfProgramacion web al lado del servidor.pdf
Programacion web al lado del servidor.pdf
 
15-Unidad 4: Introducción a las Arquitecturas Web 4.1 DAO 4.2 MVC
15-Unidad 4: Introducción a las Arquitecturas Web 4.1 DAO 4.2 MVC15-Unidad 4: Introducción a las Arquitecturas Web 4.1 DAO 4.2 MVC
15-Unidad 4: Introducción a las Arquitecturas Web 4.1 DAO 4.2 MVC
 
Sistemas Operativos
Sistemas OperativosSistemas Operativos
Sistemas Operativos
 
2009_asp.net_capitulo_1
2009_asp.net_capitulo_12009_asp.net_capitulo_1
2009_asp.net_capitulo_1
 
0. Antecedentes Asp
0. Antecedentes Asp0. Antecedentes Asp
0. Antecedentes Asp
 
Clase12-ServidoresWeb.pdf
Clase12-ServidoresWeb.pdfClase12-ServidoresWeb.pdf
Clase12-ServidoresWeb.pdf
 

Último

EPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveEPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveFagnerLisboa3
 
Avances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanaAvances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanamcerpam
 
Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21mariacbr99
 
pruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNITpruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNITMaricarmen Sánchez Ruiz
 
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptxEL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptxMiguelAtencio10
 
Avances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estosAvances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estossgonzalezp1
 
Refrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdf
Refrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdfRefrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdf
Refrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdfvladimiroflores1
 
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...JohnRamos830530
 
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptxPROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptxAlan779941
 
How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.FlorenciaCattelani
 
Modulo-Mini Cargador.................pdf
Modulo-Mini Cargador.................pdfModulo-Mini Cargador.................pdf
Modulo-Mini Cargador.................pdfAnnimoUno1
 

Último (11)

EPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveEPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial Uninove
 
Avances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanaAvances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvana
 
Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21
 
pruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNITpruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNIT
 
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptxEL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
 
Avances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estosAvances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estos
 
Refrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdf
Refrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdfRefrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdf
Refrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdf
 
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
 
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptxPROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
 
How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.
 
Modulo-Mini Cargador.................pdf
Modulo-Mini Cargador.................pdfModulo-Mini Cargador.................pdf
Modulo-Mini Cargador.................pdf
 

Programación web

  • 2. Arquitectura de las aplicaciones Web. Arquitectura de dos niveles: Es la más simple, se tiene el nivel del “Cliente” y el nivel del “Servidor”.
  • 3. Arquitectura Web de tres niveles: • El primer nivel consiste en la capa de presentación que incluye no sólo el navegador, sino también el servidor web que es el responsable de dar a los datos un formato adecuado. El segundo nivel está referido habitualmente a algún tipo de programa o script. Finalmente, el tercer nivel proporciona al segundo los datos necesarios para su ejecución.
  • 4. Lenguajes de programación del lado del cliente. • Los programas del lado del cliente están incluidos dentro de la página HTML, se descargan del servidor junto con este. • Los programas se ejecutan dentro del ámbito del browser.
  • 5. Tecnologías y lenguajes del lado del cliente. – Navegadores para Web. – HTML. – Javascript y Vbscript. – Applets en Java. – Flash (lenguaje ActionScript). – XML. – PDF. – AJAX, acrónimo de Asynchronous JavaScript And XML (JavaScript asíncrono y XML).
  • 6. Lenguajes del lado del cliente • Algunos navegadores Web. – Amaya – Epiphany – Galeon – Internet Explorer – Konqueror – Lynx – Mozilla suite navigator – Mozilla Firefox – Netscape Navigator – Opera – Safari – Shiira – Maik Navigator
  • 7. Tecnologías y lenguajes del lado del cliente. • Algunos de estos lenguajes y tecnologías requieren de un programa especial (plug-in) instalado en la computadora del usuario. Ejemplo: Adobe Flash Player. • Un complemento (o plug-in en inglés) es una aplicación que se relaciona con otra para aportarle una función nueva y generalmente muy especifica. Esta aplicación adicional es ejecutada por la aplicación principal e interactúan por medio de la API.
  • 8. Lenguajes de programación del lado del servidor. • Se ejecutan en el servidor de Web y son dependientes de la plataforma del servidor. • Se usan para acceder a recursos del servidor, como bases de datos y generación de contenido dinámico para las páginas.
  • 9. Lenguajes de programación del lado del servidor. • Por ejemplo, el ámbito de ejecución de una página ASP.NET.
  • 10. Lenguajes de programación del lado del servidor. Algunos ejemplos de lenguajes del lado del servidor: • ASP, ASP.NET (son tecnologías, soportan diferentes lenguajes como VB, C#, C++, etc.). • PHP. • JSP. • Perl. • Ruby. • Python. • XML.
  • 11. Servidor Web • Un servidor web es un programa que implementa el protocolo HTTP ). Este protocolo pertenece a la capa de aplicación del modelo OSI y está diseñado para transferir lo que se llama hipertextos, páginas web o páginas HTML: textos complejos con enlaces, figuras, formularios, botones y objetos incrustados como animaciones o reproductores de música.
  • 12. Servidor Web. • Algunos ejemplos: – CERN httpd – Apache (Libre, servidor más usado del mundo, según Wikipedia) – IIS – Resin – Tomcat(Libre, del proyecto Jakarta de Apache) – Geronimo(Libre, orientado a J2EE, del proyecto Jakarta de Apache, actualmente se encuentra en desarrollo) – JBoss – JOnAS – Cherokee
  • 13. Ambientes para el desarrollo de aplicaciones Web. • Los IDE (ambientes integrados de desarrollo) para aplicaciones Web son muy numerosos. • Considerar los que permitan trabajar con los diferentes lenguajes para Web. • Algunos son específicos para lenguajes del lado del servidor. Por ejemplo, Visual Studio solo soporta ASP.NET del lado del servidor. • Existen IDE’s de buena cantidad, libres y gratuitos de buena calidad.
  • 14. Ambientes para el desarrollo de aplicaciones Web. • Algunos ejemplos de IDE para Web: – Microsoft Visual Studio. – Microsoft Web Developer Express. – Mono (para ASP.NET). – NetBeans. – Jbuilder. – Eclipse.
  • 15. Metodologías para el desarrollo de aplicaciones Web. • Ciclo de vida clásico. Pressman, “adapta” esta metodología para el desarrollo de Web, en lo que el llama la “Ingeniería Web”: – Formulación. – Planificación. – Análisis (contenido, interacción, funcional, configuración). – Diseño (arquitectónico, navegación, interfaz, de base de datos). – Implementación. – Pruebas.
  • 16. Metodologías para el desarrollo de aplicaciones Web. • UWE UML (UML-Based Web Engineering) es una metodología de desarrollo de aplicaciones web, utilizada en la ingeniería web, prestando especial atención en sistematización y personalización (sistemas adaptativos).
  • 17. UWE UML El método UWE UML consta de seis modelos: • Modelo de casos de uso para capturar los requisitos del sistema. • Modelo conceptual para el contenido (modelo del dominio). • Modelo de usuario: modelo de navegación que incluye modelos estáticos y dinámicos. • Modelo de estructura de presentación, modelo de flujo de presentación. • Modelo abstracto de interfaz de usuario y modelo de ciclo de vida del objeto. • Modelo de adaptación.
  • 18. Aspectos de seguridad. • Las aplicaciones Web están más expuestas a ataques. Se pueden tener ataques en tres niveles: – A la computadora del usuario. – Al servidor. – A la información en tránsito.
  • 19. La seguridad en Web tiene 3 etapas primarias: – Seguridad de la computadora del usuario. – Seguridad del servidor Web y de los datos almacenados ahí. – Seguridad de la información que viaja entre el servidor Web y el usuario.
  • 20. Seguridad de la computadora del usuario • Los usuarios deben contar con navegadores y plataformas seguras, libres de virus y vulnerabilidades. También debe garantizarse la privacidad de los datos del usuario.
  • 21. Seguridad del servidor Web y de los datos almacenados ahí • Se debe garantizar la operación continua del servidor, que los datos no sean modificados sin autorización (integridad) y que la información sólo sea distribuida a las personas autorizadas (control de acceso).
  • 22. • Seguridad de la información que viaja entre el servidor Web y el usuario. Garantizar que la información en tránsito no sea leída (confidencialidad), modificada o destruida por terceros. También es importante asegurar que el enlace entre cliente y servidor no pueda interrumpirse fácilmente (disponibilidad).
  • 23. Recomendaciones: Asegurar el servidor Se deben considerar los siguientes puntos: • Asegurar el servidor en una forma fundamental: el sistema operativo, ya sea por medio de actualizaciones (parches) y habilitando los mecanismos propios de la plataforma. • Garantizar la seguridad del servidor Web propiamente (IIS, Apache, etc.) • Auditar las aplicaciones que interactúan en las dos capas anteriores (módulos, bibliotecas).
  • 24. Recomendaciones: Asegurar la información en tránsito Esto se puede lograr por diversos medios: • Asegurando la red físicamente (switches en lugar de hubs). • Esconder la información (esteganografía). • Cifrar la información (criptografía) por medio de algoritmos diversos (SSL, VPNs).
  • 25. Recomendaciones: Asegurar el equipo del usuario Vulnerar el equipo del usuario quizás no tenga el impacto de vulnerar el servidor, sin embargo es un problema más difícil de erradicar (1 servidor, 5000 clientes): • Aplicar actualizaciones (parches) al sistema operativo. • Uso de antivirus, firewalls personales. • Educación de los usuarios.