Skip to content

2. Fundamentos de la programación web

El objetivo principal de este capítulo es dar a conocer los principios fundamentales de la programación web, que son independientes de la tecnología concreta que se utilice para implementarlos. Presenta numerosos ejemplos que se recomienda probar para «familiarizarse» poco a poco con la filosofía del desarrollo web. El lector que ya cuente con estos conocimientos puede pasar directamente al siguiente capítulo.

Los componentes de una aplicación web son los siguientes:

Image

Número
Función
Ejemplos habituales
1
OS Servidor
Unix, Linux, Windows
2
Servidor web
Apache (Unix, Linux, Windows)
IIS (Windows + plataforma .NET)
Node.js (Unix, Linux, Windows)
3
Códigos ejecutados en el lado del servidor. Pueden ser ejecutados por módulos del servidor o por programas externos al servidor (CGI).
JAVASCRIPT (Node.js)
PHP (Apache, IIS)
JAVA (Tomcat, WebSphere, JBoss, WebLogic, ...)
C#, VB.NET (IIS)
4
Base de datos: puede estar en el mismo equipo que el programa que la utiliza o en otro a través de Internet.
Oracle (Linux, Windows)
MySQL (Linux, Windows)
Postgres (Linux, Windows)
SQL Server (Windows)
5
OS Cliente
Unix, Linux, Windows
6
Navegador web
Chrome, Internet Explorer, Firefox, Opera, Safari, ...
7
Scripts ejecutados en el lado del cliente dentro del navegador. Estos scripts no tienen acceso alguno a los discos del equipo del cliente.
JavaScript (cualquier navegador)

2.1. Intercambio de datos en una aplicación web con formulario

Image

Número
Función
1
El navegador solicita un URL por primera vez: (http://machine/url). No se pasa ningún parámetro.
2
El servidor web le envía la página web correspondiente a este URL. Esta puede ser estática o generada dinámicamente por un script del servidor (SA) que puede haber utilizado el contenido de bases de datos (SB, SC). En este caso, el script detectará que se ha solicitado el archivo URL sin pasar parámetros y generará la página web inicial.
El navegador recibe la página y la muestra (CA). Es posible que unos scripts del lado del navegador (CB) hayan modificado la página inicial enviada por el servidor. A continuación, mediante interacciones entre el usuario (CD) y los scripts (CB), la página web se modificará. En concreto, se rellenarán los formularios.
3
El usuario valida los datos del formulario, que a continuación deben enviarse al servidor web. El navegador vuelve a solicitar la página inicial URL u otra, según el caso, y transmite al mismo tiempo al servidor los valores del formulario. Para ello, puede utilizar dos métodos denominados GET y POST. Al recibir la solicitud del cliente, el servidor activa el script (SA) asociado a la URL solicitada, script que detectará los parámetros y los procesará.
4
El servidor envía la página web generada por el programa (SA, SB, SC). Este paso es idéntico al paso 2 anterior. A partir de ahora, los intercambios se realizan siguiendo los pasos 2 y 3.

2.2. Páginas web estáticas, páginas web dinámicas

Una página estática está representada por un archivo HTML. Una página dinámica es una página HTML generada «sobre la marcha» por el servidor web.

2.2.1. Página estática HTML (lenguaje de marcado HyperText)

Creemos un primer proyecto web con Visual Studio Express 2012. Utilizamos la opción [Fichier / Nouveau projet]:

  • en [1], se indica que queremos crear una aplicación ASP.NET vacía;
  • en [2], el nombre de la solución de Visual Studio. Todos los ejemplos de este documento se incluirán en la misma solución;
  • en [3], la carpeta principal de la que forma parte el proyecto que se va a crear;
  • en [4], el nombre del proyecto.

Confirmamos.

El proyecto resultante se muestra en [5]. Lo utilizaremos para ilustrar los principios básicos de la programación web.

Empecemos por crear una página estática HTML:

  • en [1], haz clic con el botón derecho del ratón sobre el proyecto y sigue las opciones;
  • en [2], asigna un nombre a la página;
  • a [3]; la página se ha añadido.

El contenido de la página creada es el siguiente:


<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
</head>
<body>

</body>
</html>
  • líneas 2-10: el código está delimitado por la etiqueta raíz <html>;
  • líneas 3-6: la etiqueta <head> delimita lo que se denomina el encabezado de la página;
  • líneas 7-9: la etiqueta <body> delimita lo que se conoce como el cuerpo de la página.

Modifiquemos este código de la siguiente manera:


<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>essai 1 : une page statique</title>
</head>
<body>
  <h1>Une page statique...</h1>
</body>
</html>
  • línea 5: define el título de la página; se mostrará como título de la ventana del navegador en la que se visualiza la página;
  • línea 8: un texto en letra grande (<h1>).

Veamos esta página en un navegador:

  • en [1], se solicita la visualización de la página;
  • en [2], se muestra el URL de la página visualizada;
  • en [3], el título de la ventana —proporcionado por la etiqueta <title> de la página—;
  • en [4], el cuerpo de la página —proporcionado por la etiqueta <h1>.

Veamos [1], el código HTML recibido por el navegador:

  • en [2], el navegador recibió la página HTML que habíamos creado. La interpretó y la convirtió en una representación gráfica.

2.2.2. Una página ASP.NET

Creemos ahora una página ASP.NET. Se trata de una página HTML que puede contener código ejecutado en el servidor y que genera ciertas partes de la página. Seguimos un procedimiento similar al de la creación de la página HTML:

  • en [1], se llama a una página ASP.NET una [Web Form];
  • en [2], se le da un nombre a la nueva página;
  • en [3], la página se ha creado.

El código de la página creada es el siguiente:


<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="Exemple_00.WebForm1" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    
    </div>
    </form>
</body>
</html>

Encontramos etiquetas HTML que ya hemos visto anteriormente. Las etiquetas que tienen el atributo [runat= "server "] son etiquetas que serán procesadas por el servidor y transformadas en etiquetas HTML puras. Por lo tanto, lo que vemos arriba no es, como en el caso de la página estática anterior, el código HTML que recibirá el navegador. En este caso hablamos de una página dinámica: el flujo HTML enviado al servidor es generado por código ejecutado en el lado del servidor. Modifiquemos la página de la siguiente manera:


<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="Exemple_00.WebForm1" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>Démo asp.net</title>
</head>
<body>
  <form id="form1" runat="server">
    <div>
      <h1>Il est <% =DateTime.Now.ToString("hh:mm:ss") %></h1>
    </div>
  </form>
</body>
</html>
  • línea 8: le damos un título a la página;
  • línea 13: mostramos texto generado por código C#. Este código se encuentra entre las etiquetas <% %>. Este código C# muestra la hora actual en el formato horas:minutos:segundos.

Mostramos [1] esta página en un navegador:

  • en [1], se solicita la visualización de la página;
  • en [2], el URL de la página visualizada;
  • en [3], el título de la ventana —proporcionado por la etiqueta <title> de la página—;
  • en [4], el cuerpo de la página —proporcionado por la etiqueta <h1>.

Si actualizamos la página (F5), obtenemos una visualización diferente (nueva hora), mientras que el valor URL no cambia. Este es el aspecto dinámico de la página: su contenido puede cambiar con el paso del tiempo. Veamos ahora el código HTML recibido por el navegador:

  • en [1], vemos el código fuente de la página;
  • en [2]: en esta ocasión, el código HTML recibido no es el que hemos creado, sino el que ha generado el servidor web a partir de la información de nuestra página ASP.NET.

2.2.3. Conclusión

De lo anterior se desprende que las páginas dinámicas y las estáticas son de naturaleza fundamentalmente diferente.

2.3. Scripts del lado del navegador

Una página HTML puede contener scripts que serán ejecutados por el navegador. El principal lenguaje de script del lado del navegador es actualmente (septiembre de 2013) JavaScript. Se han creado cientos de bibliotecas con este lenguaje para facilitar el trabajo del desarrollador.

Creemos una nueva página HTML [1] en el proyecto ya creado:

Editaremos el archivo [HtmlPage2.html] con el siguiente contenido:


<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>exemple Javascript</title>
  <script type="text/javascript">
    function réagir() {
      alert("Vous avez cliqué sur le bouton !");
    }
  </script>
</head>
<body>
  <input type="button" value="Cliquez-moi" onclick="réagir()" />
</body>
</html>
  • línea 13: define un botón (atributo «type») con el texto «Haz clic aquí» (atributo «value»). Al hacer clic en él, se ejecuta la función JavaScript [réagir] (atributo «onclick»);
  • líneas 6-10: un script de JavaScript;
  • líneas 7-9: la función [réagir];
  • línea 8: muestra un cuadro de diálogo con el mensaje [Vous avez cliqué sur le bouton].

Veamos la página en un navegador:

  • en [1], la página mostrada;
  • en [2], el cuadro de diálogo que aparece al hacer clic en el botón.

Al hacer clic en el botón, no se produce ningún intercambio con el servidor. El navegador ejecuta el código JavaScript.

Gracias a la gran cantidad de bibliotecas de JavaScript disponibles, ahora es posible integrar auténticas aplicaciones en el navegador. Por lo tanto, se tiende a utilizar las siguientes arquitecturas:

  • 1-4: el servidor HTML es un servidor de páginas estáticas HTML5 / CSS / JavaScript;
  • 5-6: las páginas HTML5 / CSS / JavaScript generadas interactúan directamente con un servidor de datos. Este último solo proporciona datos sin formato HTML. Es el JavaScript el que las inserta en las páginas HTML que ya se encuentran en el navegador.

En esta arquitectura, el código JavaScript puede resultar pesado. Por ello, se busca estructurarlo en capas, tal y como se hace con el código del lado del servidor:

  • la capa [UI] es la que interactúa con el usuario;
  • la capa [DAO] interactúa con el servidor de datos;
  • la capa [métier] agrupa los procedimientos de negocio que no interactúan ni con el usuario ni con el servidor de datos. Esta capa puede no existir.

2.4. Las interacciones entre cliente y servidor

Volvamos a nuestro esquema inicial, que ilustraba los componentes de una aplicación web:

Image

Aquí nos centramos en las comunicaciones entre el equipo cliente y el equipo servidor. Estas se producen a través de una red y conviene recordar la estructura general de las comunicaciones entre dos equipos remotos.

2.4.1. El modelo OSI

El modelo de red abierta denominado OSI (Open Systems Interconnection Reference Model), definido por la ISO (Organización Internacional de Normalización), describe una red ideal en la que la comunicación entre máquinas puede representarse mediante un modelo de siete capas:

Cada capa recibe servicios de la capa inferior y ofrece los suyos a la capa superior. Supongamos que dos aplicaciones situadas en máquinas A y B diferentes quieren comunicarse: lo hacen a nivel de la capa Application. No necesitan conocer todos los detalles del funcionamiento de la red: cada aplicación entrega la información que desea transmitir a la capa inferior: la capa Présentation. Por lo tanto, la aplicación solo tiene que conocer las reglas de interfaz con la capa Présentation. Una vez que la información se encuentra en la capa Présentation, pasa, siguiendo otras reglas, a la capa Session y así sucesivamente, hasta que la información llega al soporte físico y se transmite físicamente al equipo de destino. Allí se someterá al proceso inverso al que se sometió en el equipo remitente.

En cada capa, el proceso emisor encargado de enviar la información la envía a un proceso receptor en la otra máquina que pertenece a la misma capa que él. Lo hace siguiendo ciertas reglas que se denominan «protocolo de la capa». Por lo tanto, el esquema de comunicación final es el siguiente:

La función de las diferentes capas es la siguiente:

Física
Garantiza la transmisión de bits a través de un soporte físico. En esta capa se encuentran los equipos terminales de procesamiento de datos (E.T.T.D), como terminales u ordenadores, así como los equipos de terminación de circuitos de datos (E.T.C.D), como moduladores/demoduladores, multiplexores y concentradores. Los aspectos más destacados a este nivel son:
  • la elección de la codificación de la información (analógica o digital)
  • la elección del modo de transmisión (síncrono o asíncrono).
Enlace de datos
Oculta las características físicas de la capa física. Detecta y corrige los errores de transmisión.
Red
Gestiona la ruta que debe seguir la información enviada a través de la red. A esto se le denomina routage: determinar la ruta que debe seguir la información para que llegue a su destinatario.
Transporte
Permite la comunicación entre dos aplicaciones, mientras que las capas anteriores solo permitían la comunicación entre máquinas. Un servicio que ofrece esta capa puede ser la multiplexación: la capa de transporte puede utilizar una misma conexión de red (de máquina a máquina) para transmitir información perteneciente a varias aplicaciones.
Sesión
En esta capa se encuentran los servicios que permiten a una aplicación abrir y mantener una sesión de trabajo en una máquina remota.
Presentación
Su objetivo es uniformizar la representación de los datos en las diferentes máquinas. Así, los datos procedentes de una máquina A serán «formateados» por la capa Présentation de la máquina A, según un formato estándar, antes de ser enviados a la red. Una vez que llegan a la capa Présentation de la máquina destinataria B, que los reconocerá gracias a su formato estándar, se reformatearán de otra manera para que la aplicación de la máquina B los reconozca.
Aplicación
En este nivel se encuentran las aplicaciones que suelen estar más cercanas al usuario, como el correo electrónico o la transferencia de archivos.

2.4.2. El modelo TCP/IP

El modelo OSI es un modelo ideal. El conjunto de protocolos TCP/IP se aproxima a él de la siguiente forma:

  • la interfaz de red (la tarjeta de red del ordenador) se encarga de las funciones de las capas 1 y 2 del modelo OSI
  • la capa IP (Protocolo de Internet) desempeña las funciones de la capa 3 (red)
  • la capa TCP (Protocolo de control de transferencia) o UDP (Protocolo de datagramas de usuario) desempeña las funciones de la capa 4 (transporte). El protocolo TCP se encarga de que los paquetes de datos intercambiados entre los equipos lleguen correctamente a su destino. Si no es así, reenvía los paquetes que se han extraviado. El protocolo UDP no realiza esta tarea, por lo que corresponde al desarrollador de aplicaciones encargarse de ello. Por eso, en Internet, que no es una red 100 % fiable, el protocolo TCP es el más utilizado. En este caso, se habla de una red TCP-IP.
  • La capa de aplicación abarca las funciones de los niveles 5 a 7 del modelo OSI.

Las aplicaciones web se encuentran en la capa Application y, por lo tanto, se basan en los protocolos TCP-IP. Las capas Application de los equipos cliente y servidor intercambian mensajes que se confían a las capas 1 a 4 del modelo para que sean encaminados a su destino. Para entenderse, las capas de aplicación de ambos equipos deben «hablar» un mismo lenguaje o protocolo. El de las aplicaciones web se denomina HTTP (HyperText Transfer Protocol). Se trata de un protocolo de tipo texto, c.a.d, mediante el cual los equipos intercambian líneas de texto a través de la red para comunicarse. Estos intercambios están estandarizados, es decir, el cliente dispone de una serie de mensajes para indicar exactamente lo que quiere al servidor y este último también dispone de una serie de mensajes para dar su respuesta al cliente. Este intercambio de mensajes tiene la siguiente forma:

Image

Cliente --> Servidor

Cuando el cliente realiza su solicitud al servidor web, envía

  1. líneas de texto en formato HTTP para indicar lo que quiere;
  2. una línea en blanco;
  3. opcionalmente, un documento.

Servidor --> Cliente

Cuando el servidor responde al cliente, envía

  1. líneas de texto en formato HTTP para indicar lo que envía;
  2. una línea en blanco;
  3. opcionalmente, un documento.

Por lo tanto, los intercambios tienen la misma estructura en ambos sentidos. En ambos casos, puede enviarse un documento, aunque es poco habitual que un cliente envíe un documento al servidor. Pero el protocolo HTTP lo prevé. Esto es lo que permite, por ejemplo, a los abonados de un proveedor de acceso descargar diversos documentos en su sitio web personal alojado en dicho proveedor. Los documentos intercambiados pueden ser de cualquier tipo. Tomemos como ejemplo un navegador que solicita una página web que contiene imágenes:

  1. el navegador se conecta al servidor web y solicita la página que desea. Los recursos solicitados se identifican de forma única mediante URL (Uniform Resource Locator). El navegador solo envía encabezados HTTP y ningún documento.
  2. El servidor le responde. En primer lugar, envía encabezados HTTP que indican qué tipo de respuesta envía. Puede tratarse de un error si la página solicitada no existe. Si la página existe, el servidor indicará en los encabezados HTTP de su respuesta que, tras estos, enviará un documento HTML (HyperText Markup Language). Este documento es una secuencia de líneas de texto en formato HTML. Un texto HTML contiene etiquetas (marcadores) que proporcionan al navegador instrucciones sobre cómo mostrar el texto.
  3. El cliente sabe, a partir de los encabezados HTTP del servidor, que va a recibir un documento HTML. Analizará dicho documento y quizá se dé cuenta de que contiene referencias a imágenes. Estas no se encuentran en el documento HTML. Por lo tanto, realiza una nueva solicitud al mismo servidor web para pedir la primera imagen que necesita. Esta solicitud es idéntica a la realizada en el paso 1, salvo que el recurso solicitado es diferente. El servidor procesará esta solicitud enviando al cliente la imagen solicitada. En esta ocasión, en su respuesta, los encabezados HTTP especificarán que el documento enviado es una imagen y no un documento HTML.
  4. El cliente recupera la imagen enviada. Los pasos 3 y 4 se repetirán hasta que el cliente (por lo general, un navegador) disponga de todos los documentos que le permitan mostrar la página completa.

2.4.3. El protocolo HTTP

Veamos el protocolo HTTP con algunos ejemplos. ¿Qué se intercambian un navegador y un servidor web?

El servicio web o servicio HTTP es un servicio TCP-IP que suele funcionar en el puerto 80. Podría funcionar en otro puerto. En ese caso, el navegador cliente se vería obligado a especificar dicho puerto en la solicitud URL que realiza. Una solicitud tiene la siguiente forma general:

protocolo://máquina[:port]/ruta/información

donde

protocolo
http para el servicio web. Un navegador también puede actuar como cliente de servicios ftp, news, telnet, etc.
máquina
nombre del servidor en el que se ejecuta el servicio web
puerto
del servicio web. Si es el 80, se puede omitir el número de puerto. Este es el caso más habitual
ruta
ruta que designa el recurso solicitado
información
información adicional proporcionada al servidor para precisar la solicitud del cliente

¿Qué hace un navegador cuando un usuario solicita la carga de un URL?

  1. abre una comunicación TCP-IP con el equipo y el puerto indicados en la parte «equipo» [:port] del URL. Establecer una comunicación TCP-IP significa crear un «canal» de comunicación entre dos máquinas. Una vez creado este canal, toda la información intercambiada entre ambas máquinas pasará por él. La creación de este canal TCP-IP aún no implica el protocolo web HTTP.
  2. Una vez creado el canal TCP-IP, el cliente realizará su solicitud al servidor web enviándole líneas de texto (comandos) en formato HTTP. Enviará al servidor la parte «ruta/información» del URL
  3. el servidor le responderá de la misma forma y a través del mismo canal
  4. uno de los dos interlocutores tomará la decisión de cerrar el canal. Esto depende del protocolo HTTP utilizado. Con el protocolo HTTP 1.0, el servidor cierra la conexión tras cada una de sus respuestas. Esto obliga a un cliente que deba realizar varias solicitudes para obtener los distintos documentos que componen una página web a abrir una nueva conexión con cada solicitud, lo cual conlleva un coste. Con el protocolo HTTP/1.1, el cliente puede indicar al servidor que mantenga la conexión abierta hasta que le ordene cerrarla. De este modo, puede recuperar todos los documentos de una página web con una sola conexión y cerrarla él mismo una vez obtenido el último documento. El servidor detectará este cierre y también cerrará la conexión.

Para conocer los intercambios entre un cliente y un servidor web, utilizaremos la extensión [Advanced Rest Client] del navegador Chrome que hemos instalado en el apartado 1.3. Nos encontraremos en la siguiente situación:

Image

El servidor web puede ser cualquiera. Lo que buscamos aquí es descubrir los intercambios que se producirán entre el navegador y el servidor web. Anteriormente, creamos la siguiente página estática HTML:


<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>essai 1 : une page statique</title>
</head>
<body>
  <h1>Une page statique...</h1>
</body>
</html>

que visualizamos en un navegador:

 

Vemos que la URL solicitada es: http://localhost:56376/HtmlPage1.html. Por lo tanto, la máquina del servicio web es localhost (=máquina local) y el puerto es el 56376. Utilicemos la aplicación [Advanced Rest Client] para solicitar el mismo URL:

  • en [1], iniciamos la aplicación (en la pestaña [Applications] de una nueva pestaña de Chrome);
  • en [2], se selecciona la opción [Request];
  • en [3], se especifica el servidor al que se realiza la consulta: http://localhost:56376;
  • en [4], se especifica la URL solicitada: /HtmlPage1.html;
  • en [5], se añaden los posibles parámetros a la URL. Aquí no hay ninguno;
  • en [6], se especifica el comando HTTP utilizado para la consulta, en este caso GET.

Esto da como resultado la siguiente consulta:

La consulta así preparada, [7], se envía al servidor mediante [8]. La respuesta obtenida es entonces la siguiente:

Anteriormente hemos mencionado que los intercambios entre el cliente y el servidor tenían la siguiente forma:

Image

  • en [1], se ven los encabezados HTTP enviados por el navegador en su solicitud. No tenía ningún documento que enviar;
  • en [2], se ven los encabezados HTTP enviados por el servidor en respuesta. En [3], se ve el documento que envió.

En [3], se reconoce la página estática HTML que hemos colocado en el servidor web.

Analicemos la solicitud HTTP del navegador:

1
2
3
4
5
6
GET /HtmlPage1.html HTTP/1.1 
User-Agent: Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/29.0.1547.66 Safari/537.36
Content-Type: text/plain; charset=utf-8 
Accept: */*
Accept-Encoding: gzip,deflate,sdch
Accept-Language: fr-FR,fr;q=0.8,en-US;q=0.6,en;q=0.4
  • la línea 1 no ha sido mostrada por la aplicación;
  • línea 2: el navegador se identifica con el encabezado [User-Agent];
  • línea 3: el navegador indica que envía al servidor un documento de texto (text/plain) con el formato UTF-8. De hecho, en este caso, el navegador no ha enviado ningún documento;
  • línea 4: el navegador indica que acepta cualquier tipo de documento como respuesta;
  • línea 5: el navegador especifica los formatos de documento aceptados;
  • línea 6: el navegador especifica los idiomas que desea, por orden de preferencia.

El servidor le ha respondido enviando los siguientes encabezados HTTP:

HTTP/1.1 304 Not Modified 
Accept-Ranges: bytes 
Server: Microsoft-IIS/8.0 
X-SourceFiles: =?UTF-8?B?RDpcZGF0YVxpc3RpYS0xMzE0XGFzcG5ldFxkdnBcRXhlbXBsZXNcRXhlbXBsZS0wMFxIdG1sUGFnZTEuaHRtbA==?=
X-Powered-By: ASP.NET
Date: Wed, 18 Sep 2013 15:33:53 GMT 
Content-Type: text/html 
Content-Encoding: gzip 
Last-Modified: Wed, 18 Sep 2013 13:13:19 GMT 
ETag: "b474e0d770b4ce1:0" 
Vary: Accept-Encoding 
Content-Length: 313
  • línea 1: no ha sido mostrada por la aplicación;
  • línea 3: el servidor se identifica; en este caso, se trata de un servidor IIS de Microsoft;
  • línea 5: indica la tecnología que ha generado la respuesta, en este caso ASP.NET;
  • línea 6: fecha y hora de la respuesta;
  • línea 7: el tipo de documento enviado por el servidor. En este caso, un documento HTML;
  • línea 12: el tamaño en bytes del documento HTML enviado.

2.4.4. Conclusión

Hemos descubierto la estructura de la solicitud de un cliente web y la de la respuesta que le envía el servidor web a través de algunos ejemplos. El diálogo se lleva a cabo mediante el protocolo HTTP, un conjunto de comandos en formato de texto que intercambian ambas partes. La solicitud del cliente y la respuesta del servidor tienen la misma estructura, que es la siguiente:

Image

Los dos comandos habituales para solicitar un recurso son GET y POST. El comando GET no va acompañado de ningún documento. Por su parte, el comando POST sí va acompañado de un documento que, en la mayoría de los casos, es una cadena de caracteres que recoge el conjunto de valores introducidos en el formulario. El comando HEAD permite solicitar únicamente los encabezados HTTP y no va acompañado de ningún documento.

A petición de un cliente, el servidor envía una respuesta que tiene la misma estructura. El recurso solicitado se transmite en la parte [Document], salvo si el comando del cliente era HEAD, en cuyo caso solo se envían los encabezados HTTP.

2.5. Fundamentos del lenguaje HTML

Un navegador web puede mostrar diversos documentos, siendo el más habitual el documento HTML (lenguaje de marcado HyperText). Se trata de un texto formateado con etiquetas del tipo <balise>texte</balise>. Así, el texto <B>important</B> mostrará el texto importante en negrita. Existen etiquetas independientes, como la etiqueta <hr/>, que muestra una línea horizontal. No repasaremos las etiquetas que pueden encontrarse en un texto HTML. Existen numerosos programas WYSIWYG que permiten crear una página web sin escribir ni una sola línea de código HTML. Estas herramientas generan automáticamente el código HTML a partir de un diseño realizado con el ratón y controles predefinidos. De este modo, se puede insertar (con el ratón) una tabla en la página y, a continuación, consultar el código HTML generado por el programa para descubrir las etiquetas que hay que utilizar para definir una tabla en una página web. No es más complicado que eso. Por otra parte, el conocimiento del lenguaje HTML es imprescindible, ya que las aplicaciones web dinámicas deben generar por sí mismas el código HTML que se enviará a los clientes web. Este código se genera mediante un programa y, por supuesto, hay que saber qué hay que generar para que el cliente obtenga la página web que desea.

En resumen, no es necesario conocer todo el lenguaje HTML para iniciarse en la programación web. Sin embargo, este conocimiento es necesario y se puede adquirir mediante el uso de programas de creación de páginas web en WYSIWYG, como DreamWeaver y muchas otras. Otra forma de descubrir las sutilezas del lenguaje HTML es navegar por la web y visualizar el código fuente de las páginas que presentan características interesantes y que aún no conoces.

2.5.1. Un ejemplo

Consideremos el siguiente ejemplo, que presenta algunos elementos que pueden encontrarse en un documento web, tales como:

  • una tabla;
  • una imagen;
  • un enlace.

Un documento HTML tiene la siguiente estructura general:

<html>
    <head>
        <title>Un título</title>
        ...
    </head>
    <atributos del cuerpo>
        ...
    </body>
</html>

Todo el documento está enmarcado por las etiquetas <html>...</html>. Se compone de dos partes:

  1. <head>...</head>: es la parte no visible del documento. Proporciona información al navegador que va a mostrar el documento. A menudo contiene la etiqueta <title>...</title>, que establece el texto que se mostrará en la barra de título del navegador. También puede contener otras etiquetas, en particular las que definen las palabras clave del documento, palabras clave que posteriormente utilizan los motores de búsqueda. En esta parte también pueden encontrarse scripts, escritos normalmente en JavaScript o VBScript, que serán ejecutados por el navegador.
  1. <body atributos>...</body>: es la parte que mostrará el navegador. Las etiquetas HTML contenidas en esta parte indican al navegador el aspecto visual «deseado» para el documento. Cada navegador interpretará estas etiquetas a su manera. Por lo tanto, dos navegadores pueden mostrar de forma diferente un mismo documento web. Esto suele ser uno de los quebraderos de cabeza de los diseñadores web.

El código HTML de nuestro documento de ejemplo es el siguiente:


<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>balises</title>
</head>

<body style="height: 400px; width: 400px; background-image: url(images/standard.jpg)">
  <h1 style="text-align: center">Les balises HTML</h1>
  <hr />

  <table border="1">
    <thead>
      <tr>
        <th>Colonne 1</th>
        <th>Colonne 2</th>
        <th>Colonne 3</th>
      </tr>
    </thead>
    <tbody>
      <tr>
        <td>cellule(1,1)</td>
        <td style="width: 150px; text-align: center;">cellule(1,2)</td>
        <td>cellule(1,3)</td>
      </tr>
      <tr>
        <td>cellule(2,1)</td>
        <td>cellule(2,2)</td>
        <td>cellule(2,3</td>
      </tr>
    </tbody>
  </table>

  <table border="0">
    <tr>
      <td>Une image</td>
      <td>
        <img border="0" src="/images/cerisier.jpg"/></td>
    </tr>
    <tr>
      <td>le site de l'ISTIA</td>
      <td><a href="http://istia.univ-angers.fr">ici</a></td>
    </tr>
  </table>
</body>
</html>
Elemento
etiquetas y ejemplos HTML
título del documento
<title>etiquetas</title> (línea 5)
El texto balises aparecerá en la barra de título del navegador que muestre el documento
barra horizontal
<hr/>: muestra una línea horizontal (línea 10)
tabla
<table atributos>....</table>: para definir la tabla (líneas 12, 32)
<thead>...</thead>: para definir los encabezados de las columnas (líneas 13, 19)
<tbody>...</tbody>: para definir el contenido de la tabla (líneas 20 y 31)
<tr atributos>...</tr>: para definir una fila (líneas 21, 25)
<td atributos>...</td>: para definir una celda (línea 22)
Ejemplos:
<table border="1">...</table>: el atributo border define el grosor del borde de la tabla
<td style="width: 150px; text-align: center;">celda(1,2)</td>: define una celda cuyo contenido será celda(1,2). Este contenido se centrará horizontalmente (text-align: center). La celda tendrá una anchura de 150 píxeles (width: 150px)
imagen
<img border="0" src="/images/cerisier.jpg"/> (línea 38): define una imagen sin borde (border=0") cuyo archivo de origen es /images/cerisier.jpg en el servidor web (src="/images/cerisier.jpg"). Este enlace se encuentra en un documento web obtenido con el URL http://localhost:port/html/balises.htm. Por lo tanto, el navegador solicitará el archivo URL http://localhost:port/images/cerisier.jpg para obtener la imagen a la que se hace referencia aquí.
enlace
<a href="http://istia.univ-angers.fr">aquí</a> (línea 42): hace que el texto ici sirva de enlace a la imagen URL http://istia.univ-angers.fr.
fondo de la página
<body style="height:400px;width:400px;background-image:url(images/standard.jpg)"> (línea 8): indica que la imagen que debe servir como fondo de página se encuentra en la ruta URL /images/standard.jpg del servidor web. En el contexto de nuestro ejemplo, el navegador solicitará la imagen URL http://localhost:port/images/standard.jpg para obtener esta imagen de fondo. Por otra parte, el cuerpo del documento se mostrará en un rectángulo de 400 píxeles de altura y 400 píxeles de anchura.

En este sencillo ejemplo se observa que, para construir el documento completo, el navegador debe realizar tres solicitudes al servidor:

  1. http://localhost:port/html/balises.htm para obtener el código fuente HTML del documento
  2. http://localhost:port/images/cerisier.jpg para obtener la imagen cerisier.jpg
  3. http://localhost:port/images/standard.jpg para obtener la imagen de fondo standard.jpg

2.5.2. Un formulario HTML

El siguiente ejemplo muestra un formulario:

 

El código HTML que genera esta visualización es el siguiente:


<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>formulaire</title>
  <script type="text/javascript">
    function effacer() {
      alert("Vous avez cliqué sur le bouton Effacer");
    }
  </script>
</head>

<body style="height: 400px; width: 400px; background-image: url(images/standard.jpg)">
  <h1 style="text-align: center">Formulaire HTML</h1>
  <form method="post" action="FormulairePost.aspx">
    <table border="0">
      <tr>
        <td>Etes-vous marié(e)</td>
        <td>
          <input type="radio" value="Oui" name="R1" />Oui
          <input type="radio" name="R1" value="non" checked="checked" />Non
        </td>
      </tr>
      <tr>
        <td>Cases à cocher</td>
        <td>
          <input type="checkbox" name="C1" value="un" />1
          <input type="checkbox" name="C2" value="deux" checked="checked" />2
          <input type="checkbox" name="C3" value="trois" />3
        </td>
      </tr>
      <tr>
        <td>Champ de saisie</td>
        <td>
          <input type="text" name="txtSaisie" size="20" value="qqs mots" />
        </td>
      </tr>
      <tr>
        <td>Mot de passe</td>
        <td>
          <input type="password" name="txtMdp" size="20" value="unMotDePasse" />
        </td>
      </tr>
      <tr>
        <td>Boîte de saisie</td>
        <td>
          <textarea rows="2" name="areaSaisie" cols="20">
ligne1
ligne2
ligne3
</textarea>
        </td>
      </tr>
      <tr>
        <td>combo</td>
        <td>
          <select size="1" name="cmbValeurs">
            <option value="1">choix1</option>
            <option selected="selected" value="2">choix2</option>
            <option value="3">choix3</option>
          </select>
        </td>
      </tr>
      <tr>
        <td>liste à choix simple</td>
        <td>
          <select size="3" name="lst1">
            <option selected="selected" value="1">liste1</option>
            <option value="2">liste2</option>
            <option value="3">liste3</option>
            <option value="4">liste4</option>
            <option value="5">liste5</option>
          </select>
        </td>
      </tr>
      <tr>
        <td>liste à choix multiple</td>
        <td>
          <select size="3" name="lst2" multiple="multiple">
            <option value="1" selected="selected">liste1</option>
            <option value="2">liste2</option>
            <option selected="selected" value="3">liste3</option>
            <option value="4">liste4</option>
            <option value="5">liste5</option>
          </select>
        </td>
      </tr>
      <tr>
        <td>bouton</td>
        <td>
          <input type="button" value="Effacer" name="cmdEffacer" onclick="effacer()" />
        </td>
      </tr>
      <tr>
        <td>envoyer</td>
        <td>
          <input type="submit" value="Envoyer" name="cmdRenvoyer" />
        </td>
      </tr>
      <tr>
        <td>rétablir</td>
        <td>
          <input type="reset" value="Rétablir" name="cmdRétablir" />
        </td>
      </tr>
    </table>
    <input type="hidden" name="secret" value="uneValeur" />
  </form>
</body>
</html>

La correspondencia entre el control visual y la etiqueta HTML es la siguiente:

Control
etiqueta HTML
formulario
<form method="post" action="...">
campo de entrada
<input type="text" name="txtSaisie" size="20" value="unas palabras" />
campo de entrada oculto
<input type="password" name="txtMdp" size="20" value="unMotDePasse" />
campo de entrada de varias líneas
<textarea rows="2" name="areaSaisie" cols="20">
línea1
línea2
línea3
</textarea>
botones de opción
<input type="radio" value="Sí" name="R1" />
<input type="radio" name="R1" value="no" checked="checked" />No
casillas de selección
<input type="checkbox" name="C1" value="uno" />1
<input type="checkbox" name="C2" value="dos" checked="checked" />2
<input type="checkbox" name="C3" value="tres" />3
Lista desplegable
<select size="1" name="cmbValeurs">
<option value="1">opción 1</option>
<option selected="selected" value="2">opción 2</option>
<option value="3">opción 3</option>
</select>
lista de selección única
<select size="3" name="lst1">
<option selected="selected" value="1">lista1</option>
<option value="2">lista2</option>
<option value="3">lista3</option>
<option value="4">lista4</option>
<option value="5">lista5</option>
</select>
lista de selección múltiple
<select size="3" name="lst2" multiple="multiple">
<option value="1">lista1</option>
<option value="2">lista2</option>
<option selected="selected" value="3">lista3</option>
<option value="4">lista4</option>
<option value="5">lista5</option>
</select>
botón de tipo «submit»
<input type="submit" value="Enviar" name="cmdRenvoyer" />
botón de tipo «restablecer»
<input type="reset" value="Restablecer" name="cmdRétablir" />
botón de tipo «button»
<input type="button" value="Borrar" name="cmdEffacer" onclick="effacer()" />

Repasemos estas diferentes etiquetas:

2.5.2.1. El formulario « »

formulario

<form method="post" action="FormulairePost.aspx">
etiqueta HTML
<form name="..." method="..." action="...">...</form>
atributos
name="frmexemple": nombre del formulario
method="..." : método utilizado por el navegador para enviar al servidor web los valores recopilados en el formulario
action="..." : URL a la que se enviarán los valores recopilados en el formulario.
Un formulario web está delimitado por las etiquetas <form>...</form>. El formulario puede tener un nombre (name="xx"). Esto se aplica a todos los controles que pueden encontrarse en un formulario. El objetivo de un formulario es recopilar la información introducida por el usuario mediante el teclado o el ratón y enviarla a una URL del servidor web. ¿Cuál? La que se indica en el atributo action="URL". Si este atributo no está presente, la información se enviará al documento en el que se encuentra el formulario. Un cliente web puede utilizar dos métodos diferentes, denominados POST y GET, para enviar datos a un servidor web. El atributo method="méthode", con method igual a GET o POST, de la etiqueta <form> indica al navegador el método que debe utilizar para enviar la información recopilada en el formulario a la dirección URL especificada por el atributo action="URL". Cuando no se especifica el atributo method, se utiliza por defecto el método GET.

2.5.2.2. Los campos de introducción de texto

campo de entrada
<input type="text" name="txtSaisie" size="20" value="unas palabras" />
<input type="password" name="txtMdp" size="20" value="unMotDePasse" />
 
etiqueta HTML
<input type="..." name="..." size=".." value=".."/>
La etiqueta «input» existe para diversos controles. El atributo type es el que permite diferenciar estos controles entre sí.
Atributos
type="text": especifica que se trata de un campo de entrada
type="password": los caracteres que aparecen en el campo de entrada se sustituyen por asteriscos (*). Esta es la única diferencia con respecto al campo de entrada normal. Este tipo de control es adecuado para introducir contraseñas.
size="20": número de caracteres visibles en el campo; no impide introducir más caracteres
name="txtSaisie": nombre del control
value="unas palabras": texto que se mostrará en el campo de entrada.

2.5.2.3. Los campos de entrada de varias líneas

campo de entrada multilínea
<textarea rows="2" name="areaSaisie" cols="20">
línea1
línea 2
línea 3
</textarea>
 
etiqueta HTML
<textarea ...>texto</textarea>
muestra un campo de entrada de varias líneas que contiene texto de forma predeterminada
atributos
rows="2": número de líneas
cols="'20": número de columnas
name="areaSaisie": nombre del control

2.5.2.4. Los botones de opción

Botones de radio
<input type="radio" value="Sí" name="R1" />
<input type="radio" name="R1" value="no" checked="checked" />No
 
etiqueta HTML
<input type="radio" atributo2="valor2" ..../>texto
muestra un botón de opción con texto al lado.
atributos
name="radio": nombre del control. Los botones de opción que tienen el mismo nombre forman un grupo de botones que se excluyen entre sí: solo se puede seleccionar uno de ellos.
value="valor": valor asignado al botón de opción. No hay que confundir este valor con el texto que aparece junto al botón de opción. Este último solo tiene fines de visualización.
checked="checked": si se incluye esta palabra clave, el botón de radio está marcado; de lo contrario, no lo está.

2.5.2.5. Las casillas de selección

casillas de selección
<input type="checkbox" name="C1" value="uno" />1
<input type="checkbox" name="C2" value="dos" checked="checked" />2
<input type="checkbox" name="C3" value="tres" />3
 
etiqueta HTML
<input type="checkbox" atributo2="valor2" ....>texto
muestra una casilla de selección con texto al lado.
atributos
name="C1": nombre del control. Las casillas de selección pueden tener o no el mismo nombre. Las casillas que tienen el mismo nombre forman un grupo de casillas asociadas.
value="valor": valor asignado a la casilla de selección. No hay que confundir este valor con el texto que aparece junto a la casilla de selección. Este último solo tiene fines de visualización.
checked= "checked": si está presente esta palabra clave, la casilla de selección está marcada; en caso contrario, no lo está.

2.5.2.6. La lista desplegable (combo)

Combo
<select size="1" name="cmbValeurs">
<option value="1">opción1</option>
<option selected="selected" value="2">opción 2</option>
<option value="3">opción 3</option>
</select>
 
etiqueta HTML
<select size=".." name="..">
<option [selected="selected"] value=”v”>...</option>
...
</select>
muestra en una lista los textos comprendidos entre las etiquetas <option>...</option>
atributos
name="cmbValeurs": nombre del control.
size="1": número de elementos de la lista visibles. size="1" convierte la lista en el equivalente a un cuadro combinado.
selected="selected": si esta palabra clave está presente para un elemento de la lista, este aparece seleccionado en la lista. En nuestro ejemplo anterior, el elemento de la lista choix2 aparece como el elemento seleccionado del cuadro combinado cuando este se muestra por primera vez.
value=”v”: si el usuario selecciona el elemento, es este valor ([v]) el que se envía al servidor. Si no se incluye este atributo, se envía al servidor el texto que se muestra y está seleccionado.

2.5.2.7. Lista de selección única

lista de selección única
<select size="3" name="lst1">
<option selected="selected" value="1">lista1</option>
<option value="2">lista2</option>
<option value="3">lista3</option>
<option value="4">lista4</option>
<option value="5">lista5</option>
</select>
 
etiqueta HTML
<select size=".." name="..">
<option [selected="selected"]>...</option>
...
</select>
muestra en una lista los textos comprendidos entre las etiquetas <option>...</option>
atributos
los mismos que para la lista desplegable que solo muestra un elemento. Este control solo se diferencia de la lista desplegable anterior en su atributo size>1.

2.5.2.8. Lista de selección múltiple

Lista de selección única
<select size="3" name="lst2" multiple="multiple">
<option value="1" selected="selected">lista1</option>
<option value="2">lista2</option>
<option selected="selected" value="3">lista3</option>
<option value="4">lista4</option>
<option value="5">lista5</option>
</select>
 
etiqueta HTML
<select size=".." name=".." multiple="multiple">
<option [selected="selected"]>...</option>
...
</select>
muestra en una lista los textos comprendidos entre las etiquetas <option>...</option>
atributos
multiple: permite seleccionar varios elementos de la lista. En el ejemplo anterior, se seleccionan los elementos liste1 y liste3.

2.5.2.9. Botón de tipo «button»

botón de tipo button
<input type="button" value="Borrar" name="cmdEffacer" onclick="effacer()" />
 
etiqueta HTML
<input type="button" value="..." name="..." onclick="effacer()" ..../>
atributos
type="button": define un control de botón. Existen otros dos tipos de botón: los tipos submit y reset.
value="Borrar": el texto que se muestra en el botón
onclick="función()": permite definir una función que se ejecutará cuando el usuario haga clic en el botón. Esta función forma parte de los scripts definidos en el documento web mostrado. La sintaxis anterior es una sintaxis javascript. Si los scripts están escritos en VBScript, habría que escribir onclick="función" sin los paréntesis. La sintaxis es idéntica si hay que pasar parámetros a la función: onclick="función(val1, val2,...)"
En nuestro ejemplo, al hacer clic en el botón Effacer se invoca la siguiente función de JavaScript effacer:
<script type="text/javascript">
function borrar() {
alert("Has hecho clic en el botón Borrar");
}
</script>
La función effacer muestra un mensaje:

2.5.2.10. Botón de tipo «submit»

Botón de tipo «submit»
<input type="submit" value="Enviar" name="cmdRenvoyer" />
 
etiqueta HTML
<input type="submit" value="Enviar" name="cmdRenvoyer" />
atributos
type="submit": define el botón como un botón para enviar los datos del formulario al servidor web. Cuando el usuario haga clic en este botón, el navegador enviará los datos del formulario a la URL URL definida en el atributo action de la etiqueta <form>, según el método definido por el atributo method de dicha etiqueta.
value="Enviar": el texto que se muestra en el botón

2.5.2.11. Botón de tipo «reset»

Botón de tipo «reset»
<input type="reset" value="Restablecer" name="cmdRétablir" />
 
etiqueta HTML
<input type="reset" value="Restablecer" name="cmdRétablir"/>
atributos
type="reset": define el botón como un botón de restablecimiento del formulario. Cuando el usuario haga clic en este botón, el navegador restablecerá el formulario al estado en el que lo recibió.
value="Restablecer": el texto que se muestra en el botón

2.5.2.12. Campo oculto

campo oculto
<input type="hidden" name="secret" value="uneValeur" />
etiqueta HTML
<input type="hidden" name="..." value="..."/>
atributos
type="hidden": indica que se trata de un campo oculto. Un campo oculto forma parte del formulario, pero no se muestra al usuario. Sin embargo, si este solicitara a su navegador que mostrara el código fuente, vería la presencia de la etiqueta <input type="hidden" value="..."> y, por lo tanto, el valor del campo oculto.
value="unValor": valor del campo oculto.
¿Para qué sirve el campo oculto? Permite al servidor web conservar información a lo largo de las solicitudes de un cliente. Pensemos en una aplicación de compras en la web. El cliente compra un primer artículo art1 en una cantidad de q1 en una primera página de un catálogo y, a continuación, pasa a otra página del catálogo. Para recordar que el cliente ha comprado q1 artículos art1, el servidor puede introducir estos dos datos en un campo oculto del formulario web de la nueva página. En esta nueva página, el cliente compra los artículos q2 y art2. Cuando los datos de este segundo formulario se envíen al servidor (submit), este no solo recibirá la información (q2, art2), sino también (q1, art1), que también forma parte del formulario como campo oculto. A continuación, el servidor web colocará en un nuevo campo oculto la información (q1,art1) y (q2,art2) y enviará una nueva página del catálogo. Y así sucesivamente.

2.5.3. Envío de los valores de un formulario a un servidor web por parte de un cliente web

En el estudio anterior mencionamos que el cliente web dispone de dos métodos para enviar a un servidor web los valores de un formulario que ha mostrado: los métodos GET y POST. Veamos con un ejemplo la diferencia entre ambos métodos.

2.5.3.1. Método GET

Hagamos una primera prueba, en la que, en el código HTML del documento, la etiqueta <form> se define de la siguiente manera:


<form method="get" action="FormulaireGet.aspx">

Cuando el usuario haga clic en el botón [1], los valores introducidos en el formulario se enviarán a la página ASP.NET [2]. Esta página no realiza ninguna acción con dichos parámetros y devuelve una página vacía. Solo queremos saber cómo transmite el navegador los valores introducidos al servidor web. Para ello, vamos a utilizar una herramienta de depuración disponible en Chrome. Se activa escribiendo CTRL-I (en mayúsculas) [3]:

Como nos interesan las comunicaciones de red entre el navegador y el servidor web, activamos la pestaña [Network] y, a continuación, hacemos clic en el botón [Envoyer] del formulario. Se trata de un botón de tipo [submit] dentro de una etiqueta [form]. El navegador responde al clic solicitando el URL [FormulaireGet.aspx] indicado en el atributo [action] de la etiqueta [form], con el método GET indicado en el atributo [method]. De este modo, obtenemos la siguiente información:

La captura de pantalla anterior nos muestra el URL solicitado por el navegador tras hacer clic en el botón [envoyer]. Efectivamente, solicita el URL previsto ([FormulaireGet.aspx]), pero al final añade información que corresponde a los valores introducidos en el formulario. Para obtener más información, hacemos clic en el enlace anterior:

En el ejemplo anterior, [1, 2], vemos los encabezados HTTP enviados por el navegador. Aquí se han formateado. Para ver el texto sin formato de estos encabezados, seguimos el enlace [view source] [3, 4]. El texto completo es el siguiente:

GET /FormulaireGet.aspx?R1=Oui&C1=un&C2=deux&txtSaisie=programmation+web&txtMdp=ceciestsecret&areaSaisie=les+bases+de+la%0D%0Aprogrammation+web&cmbValeurs=3&lst1=3&lst2=1&lst2=3&cmdRenvoyer=Envoyer&secret=uneValeur HTTP/1.1
Host: localhost:56376
Connection: keep-alive
Pragma: no-cache
Cache-Control: no-cache
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/38.0.2125.111 Safari/537.36
Referer: http://localhost:56376/HtmlFormulaire.html
Accept-Encoding: gzip,deflate,sdch
Accept-Language: fr-FR,fr;q=0.8,en-US;q=0.6,en;q=0.4

Encontramos elementos que ya habíamos visto anteriormente. Otros aparecen por primera vez:

Connection: keep-alive
el cliente solicita al servidor que no cierre la conexión tras su respuesta. Esto le permitirá utilizar la misma conexión para una solicitud posterior. La conexión no permanece abierta indefinidamente. El servidor la cerrará tras un periodo de inactividad demasiado prolongado.
Referer
el URL que se mostraba en el navegador cuando se realizó la nueva solicitud.

La novedad se encuentra en la línea 1 de la información que sigue al URL. Se observa que las opciones seleccionadas en el formulario aparecen en el URL. Los valores introducidos por el usuario en el formulario se han pasado a la orden GET URL?param1=valor1&param2=valor2&... HTTP/1.1, donde parami son los nombres (atributo name) de los controles del formulario web y valeuri los valores asociados a ellos. A continuación se muestra una tabla de tres columnas:

  • columna 1: recoge la definición de un control HTML del ejemplo;
  • columna 2: muestra cómo se visualiza este control en un navegador;
  • columna 3: muestra el valor enviado al servidor por el navegador para el control de la columna 1, tal y como aparece en la solicitud GET del ejemplo.

control HTML


Visualización


valor(es) devuelto(s)

<input type="radio" value="Sí" name="R1"/>Sí
<input type="radio" name="R1" value="no" checked="checked"/>No
R1=Sí
- el valor del atributo value del botón de radio marcado por el usuario.
<input type="checkbox" name="C1" value="uno"/>1
<input type="checkbox" name="C2" value="dos" checked="checked"/>2
<input type="checkbox" name="C3" value="tres"/>3
C1=uno
C2=dos
- valores de los atributos value de las casillas marcadas por el usuario
<input type="text" name="txtSaisie" size="20" value="unas palabras"/>
txtSaisie = programación + Web
- texto introducido por el usuario en el campo de entrada. Los espacios se han sustituido por el signo +
<input type="password" name="txtMdp" size="20" value="unMotDePasse"/>
txtMdp=estoesecreto
- texto introducido por el usuario en el campo de entrada
<textarea rows="2" name="areaSaisie" cols="20">
línea1
línea 2
línea 3
</textarea>
areaIntroducción=los+fundamentos+de+la%0D%0A
programación+web
- Texto introducido por el usuario en el campo de entrada. %OD%OA es el marcador de fin de línea. Los espacios se han sustituido por el signo +
<select size="1" name="cmbValeurs">
<option value='1'>opción1</option>
<option selected="selected" value='2'>opción2</option>
<option value='3'>opción3</option>
</select>
cmbValores=3
- atributo [value] del elemento seleccionado por el usuario
<select size="3" name="lst1">
<option selected="selected" value='1'>lista1</option>
<option value='2'>lista2</option>
<option value='3'>lista3</option>
<option value='4'>lista4</option>
<option value='5'>lista5</option>
</select>
lst1=3
- atributo [value] del elemento seleccionado por el usuario
<select size="3" name="lst2" multiple="multiple">
<option selected="selected" value='1'>lista1</option>
<option value='2'>lista2</option>
<option selected="selected" value='3'>lista3</option>
<option value='4'>lista4</option>
<option value='5'>lista5</option>
</select>
lst2=1
lst2=3
- Atributos [value] de los elementos seleccionados por el usuario
<input type="submit" value="Enviar" name="cmdRenvoyer"/>
 
cmdRenvoyer=Enviar
- nombre y atributo value del botón que se ha utilizado para enviar los datos del formulario al servidor
<input type="hidden" name="secret" value="uneValeur"/>
 
secret=unValor
- atributo value del campo oculto

2.5.3.2. Método POST

Modificamos el documento HTML para que el navegador utilice ahora el método POST para enviar los valores del formulario al servidor web:


  <form method="post" action="FormulairePost.aspx">

Rellenamos el formulario igual que para el método GET y enviamos los parámetros al servidor con el botón [Envoyer]. Al igual que se hizo en el párrafo anterior de la página 34, en Chrome tenemos acceso a los encabezados HTTP de la solicitud enviada por el navegador:

POST /FormulairePost.aspx HTTP/1.1
Host: localhost:56376
Connection: keep-alive
Content-Length: 195
Pragma: no-cache
Cache-Control: no-cache
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0,8
Origin: http://localhost:56376
User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/38.0.2125.111 Safari/537.36
Content-Type: application/x-www-form-urlencoded
Referer: http://localhost:56376/HtmlFormulaire.html
Accept-Encoding: gzip,deflate
Accept-Language: fr-FR,fr;q=0.8,en-US;q=0.6,en;q=0.4

R1=Oui&C1=un&C2=deux&txtSaisie=programmation+web&txtMdp=unMotDePasse&areaSaisie=les+bases+de+la%0D%0Aprogrammation+web%0D%0A&cmbValeurs=3&lst1=3&lst2=1&lst2=3&cmdRenvoyer=Envoyer&secret=uneValeur

Aparecen novedades en la solicitud HTTP del cliente:

POST URL HTTP/1.1
La consulta GET ha dado paso a la consulta POST. Los parámetros ya no aparecen en esta primera línea de la consulta. Se puede observar que ahora se encuentran (línea 14) después de la consulta HTTP, tras una línea en blanco. Su codificación es idéntica a la que tenían en la consulta GET.
Content-Length
número de caracteres «enviados», c.a.d. El número de caracteres que deberá leer el servidor web tras recibir los encabezados HTTP para recuperar el documento que le envía el cliente. El documento en cuestión es, en este caso, la lista de valores del formulario.
Content-type
especifica el tipo de documento que el cliente enviará tras los encabezados HTTP. El tipo [application/x-www-form-urlencoded] indica que se trata de un documento que contiene valores de formulario.

Existen dos métodos para transmitir datos a un servidor web: GET y POST. ¿Hay algún método mejor que el otro? Hemos visto que, si los valores de un formulario se enviaban desde el navegador con el método GET, el navegador mostraba en su campo Adresse la URL solicitada en el formato URL?param1=val1&param2=val2&.... Esto puede considerarse una ventaja o un inconveniente:

  • una ventaja si se quiere permitir al usuario añadir este URL configurado a sus favoritos;
  • un inconveniente si no se desea que el usuario tenga acceso a cierta información del formulario, como, por ejemplo, los campos ocultos.

A partir de ahora, utilizaremos casi exclusivamente el método POST en nuestros formularios.

2.6. Conclusion

En este capítulo se han presentado diferentes conceptos básicos del desarrollo web:

  • las comunicaciones cliente-servidor a través del protocolo HTTP;
  • el diseño de un documento mediante el lenguaje HTML;
  • el diseño de formularios de introducción de datos.

Hemos visto en un ejemplo cómo un cliente puede enviar información al servidor web. No hemos explicado cómo el servidor puede

  • recuperar esa información;
  • procesarla;
  • enviar al cliente una respuesta dinámica en función del resultado del procesamiento.

Este es el ámbito de la programación web, tema que abordaremos en el siguiente capítulo con la presentación de la tecnología ASP.NET MVC.