Sirvidor web

ordenador en rede qu’agospia o forne un sitiu o aplicación web

Un sirvidor web o sirvidor HTTP ye un programa informáticu que procesa una aplicación del llau del sirvidor, realizando conexones bidireccionales o unidireccionales y síncrones o asíncrones col veceru y xenerando o dexando una respuesta en cualquier llinguaxe o Aplicación del llau del veceru. El códigu recibíu pol veceru lu procesa por un restolador web. Pa la tresmisión de toos estos datos suel utilizase dalgún protocolu. Xeneralmente úsase'l protocolu HTTP pa estes comunicaciones, perteneciente a la capa d'aplicación del modelu OSI. El términu tamién s'emplega pa referise al ordenador.

Ficha de softwareSirvidor web
Tipu funcionalidá de software y tipu de software
Etiqueta de Stack Exchange Stack Exchange
Cambiar los datos en Wikidata

Arquiteutura

editar

Pidimientu GET

editar

Un sirvidor web opera por aciu el protocolu HTTP, de la capa d'aplicación del modelu OSI. Al protocolu HTTP asígnase-y davezu'l puertu TCP 80. Los pidimientos al sirvidor suelen realizase por aciu HTTP utilizando'l métodu de pidimientu GET, nel que'l recursu solicítase al traviés de la url al sirvidor Web.
GET /index.html HTTP/1.1 HOST: www.host.com

Na barra d'URL d'un restolador cualesquier, el pidimientu anterior sería análogu a la siguiente direición Web:

www.host.com/index.html

Esquema d'un pidimientu GET

editar
Pidimientu Web
editar

El restolador, per mediu de la interfaz d'usuariu, dexa al usuariu realizar una o dellos pidimientos Web. La interfaz d'usuariu o redolada d'usuariu ye'l conxuntu d'elementos del restolador que dexen realizar el pidimientu de forma activa. Un pidimientu Web non solo pue facese por aciu un restolador, sinón con cualquier ferramienta habilitada pa tal fin, como una consola de comandos Telnet.

Elementos de la redolada d'usuariu más comunes en restoladores Web visuales:

Nome Descripción
Hiperenllaz enllaz o link Ye una porción de conteníu Web, testu, imaxe y otros elementos, qu'enllaza con unes señes Web. Al calcar un hiperenllaz, el restolador xenera un pidimientu GET automáticu al URL de dichu enllaz.
Formulariu web Al realizar l'unviu satisfactoriu de los datos d'un formulariu, el restolador Web xenera un pidimientu GET o POST (comúnmente POST) automáticu al par qu'unvia los datos al sirvidor.
Barra de señes Tolos restoladores inclúin una barra de señes por aciu la cual puede aportase manualmente a cualquier direición URL, de cuenta que'l restolador va xenerar un pidimientu GET automática a dicha URL cada vegada que l'usuariu deseyar.
Script activu o pasivu Cualquier aplicación JavaScript tien accesu al estáu del restolador, cómo puede modificar los datos que describen tal estáu, de forma pasiva (ensin la intervención del usuariu) o activa (por aciu dalguna aición del usuariu).

===== 1.1 Socket a señes DNS produz una socket con un sirvidor dau en direición IP por aciu TCP. Polo xeneral les señes que'l restolador tien primeramente son señes DNS (señes alfanumériques) que tendrá de convertir a señes numbériques.

1.2 Resolvimientu de DNS a IP
editar

Si les señes daes son DNS y nun esiste una regla na base de datos DNS, el Host Resolver Request solicita al sirvidor DNS la o les señes IP correspondientes. El restolador crea una nueva regla y almacena les señes IP xunto a les señes DNS na so base de datos de regles DNS.

1.3 Recuperación de reglar DNS
editar

Una vegada almacenada la regla, realízase un pidimientu a la base de datos DNS pa recuperar los valores de la regla.

===== 1.4 Socket a señes IP produz una socket cola direición IP por aciu TCP. Les señes IP puen recuperase nel pasu anterior.

SOCKET 192.168.0.1

===== 1.5 Preparación del pidimientu créase la pidimientu GET estableciendo la url ,un flag ,la priority del pidimientu y el method (implícitamente GET).

1.6 Apertura Caché
editar

Ábrese y/o se crea una entrada nel http cache.

===== 1.7 Efeutuación de la pidimientu realiza la pidimientu GET. Lléense les cabeceres HTTP de la http transaction y más tarde el cuerpu de la http transaction.

GET /index.html HTTP/1.1
1.8 Consulta en Caxé
editar

Consultar nel caxé de discu si esiste una entrada nel caxé acomuñada al recursu que se solicitó. Los valores son created (true o false) y key (la url del recursu).

1.9 Respuesta booleana de la esistencia del recursu solicitáu
editar

Si la entrada nun esiste (si'l valor de created ye false) escríbense los datos nel caxé de discu. Si non, lléese direutamente.

===== 2.0 Presentación visual del recursu conclúyese la operación y amuésase en pantalla (si ye precisu) la información.

Pidimientu GET pasiva

editar

Javascript dexa realizar cambeos nel estáu del restolador. L'estáu del restolador vien definíu pol array d'oxetos location del oxetu global Window. Referenciar a tal oxetu con window.location. En concretu window.location.href contién les señes actuales del restolador Web.

Si una parte del script executa tal sentencia:

window.location.href='http://wikipedia.org';

El restolador va faer tal pidimientu Web ensin que l'usuariu mediara en tal circunstancia o los sos efeutos. De la mesma va producise un nuevu pidimientu GET si altériase'l valor de window.location.search o window.location.protocol.

Procedimientu del restolador

editar

La xera del restolador Web ye crear el pidimientu a partir de los datos recoyíos na redolada d'usuariu d'elementos del mesmu, como enllaces, el valor del testu de la barra de busca, los metatags.

<a href="http://es.wikipedia.org">Entrar</a>

Al pulsiar nel enllaz, el restolador crea automáticamente el pidimientu GET y les cabeceres del pidimientu sobre la base de los metatags (cabeceres definíes), los cookies y cabeceres automátiques del restolador, pa depués unviales xunto al pidimientu al Sirvidor.

Pidimientu POST

editar

Ye'l segundu tipu de pidimientu HTTP más utilizáu. Los datos a unviar al sirvidor incluyir nel cuerpu del mesmu pidimientu coles cabeceres HTTP asignaes correspondientemente respectu al tipu de pidimientu. Xeneralmente acomúñase colos formulario web nos que los datos suelen ser cifraos pa unvialos de manera segura al sirvidor.

Por motivos de convención incluyir nel pidimientu la cabecera application/x-www-form-urlencoded, qu'indica'l formatu o codificación de los datos a unviar; esta ye variable->valor nel formatu: variable=valor separada cada par variable->valor por &. Esta cabecera, nos formularios HTML únviase automáticamente, pero n'otres teunoloxíes web tal como AJAX, si deseyar faer correutamente un pidimientu POST, ten de ser especificáu o instanciado l'oxetu: setRequestHeader("Content-type:application/x-www-form-urlencode"); ajax.send(data);

Si utilizara'l métodu GET los datos deberíen de ser añadíos a la URL, lo que los espondría a ser vistos de forma direuta.

Estructura d'un pidimientu POST

editar

Estructura típica d'un pidimientu POST

Amuesa

Petition type

POST url HTTP/1.1

POST comment.php HTTP/1.1

Referer

http-url-referer

index.php

Content-Length

contentlenght-int

63

Origin

http-url-origin

http://es.wikipedia.org

User-Agent

useragent-string

Mozilla/5.0 (Windows; O; Windows NT 6.1; en-US) ...

Content-Type

content-type-string

application/x-www-form-urlencoded

Accept

mimetypes-accepted-string

application/xml,application/xhtml+xml ...

Accept-Language

language-accepted-string

es-ES,ye;q=0.8

Accept-Charset

charset-accepted-string

ISO-8859-1,utf-8;q=0.7,*;q=0.3

Cookie

phpsessid-string

PHPSESSID=gm0ugf96iojuldio8i51o92716

Accept-Encoding

accept-encoding-string

gzip,deflate,sdch

Content

Content-string

&data=4&lang=es+ye

Composición d'un pidimientu POST

editar

Les cabeceres más comunes que s'unvien nun pidimientu POST:

  • Petition type: Especifica'l tipu de pidimientu HTTP. (Esta cabecera nun tien nome, únviase talo como)
  • Referer: Especifica la url dende la cual fíxose'l pidimientu POST.
  • Content-Length: Especifica'l llargor en bytes de los datos unviaos nel cuerpu del pidimientu.
  • Origin: Especifica la url principal del sitiu.[ensin referencies]
  • User-Agent:Especifica l'identificador del restolador Web dende'l cual fíxose'l pidimientu.
  • Content-Type: Especifica'l formatu o MIME de los datos unviaos nel cuerpu del pidimientu.
  • Accept: Especifica'l MIME que s'espera na respuesta.
  • Accept-Language: Especifica'l códigu del llinguaxe esperáu na respuesta.
  • Accept-Charset: Especifica la codificación que s'espera na respuesta.
  • Cookie: Especifica un identificador de sesión nel pidimientu deriváu d'un cookie.
  • Accept-Encoding: Especifica'l tipu de codificación (xeneralmente compresión) que s'espera de la respuesta. (Nun tolos restoladores unvien esta testera)

Estructura d'una respuesta POST

editar
Estructura típica d'una respuesta POST Amuesa
HTTP version & state HTTP-version-state HTTP/1.1 200 OK
Date date-string Tue, 07 Jun 2011 05:52:31 GMT
Server server-string Apache/2.2.17 (Win32) mod_ssl/2.2.17...
Expires expire-date-string Thu, 19 Nov 1981 08:52:00 GMT
Cache-Control Cache-control-string no-store, no-cache, must-revalidate...
Pragma pragma-string no-cache
Content-Length Content-length-int 297
Content-Type Content-type-string text/html
Keep-Alive Keep-alive-string timeout=5, max=98
Connection Connection-string Keep-Alive
X-Powered-By X-powered-by-string PHP/5.3.5

Codificación del mensaxe del cuerpu del pidimientu

editar

Los datos que s'unvien nel cuerpu del pidimientu POST tienen de tener dalgún formatu que dexe manipolialos nun futuru procesamientu. Por ello'l pidimientu tien de tener asignada la cabecera Content-Type que'l so valor va ser la codificación de los datos. D'esta miente el sistema va poder estremar ente variables aisllaes, datos binarios, testu planu, o cualesquier otru tipu de formatu. El formatu d'una cadena de datos denominar MIME y ye el valor que tendrá de ser incluyíu nesta cabecera.[1]

En HTML la cabecera Content-Type especifícase automáticamente y el so valor ye application/x-www-form-urlencoded, sicasí pueden especificase por estándar otros dos valores: multipart/form-data y text/plain utilizando l'atributu enctype del elementu form de la siguiente manera

<form enctype="multipart/form-data">...</form>
<form enctype="text/plain">...</form>
<form enctype="application/x-www-form-urlencoded">...</form>

O cualesquier otru valor MIME. El multipart/form-data utilizar pa unviar grandes cadenes binaries que suponen cualesquier otru tipu de documentu que nun sía testu planu, como imáxenes, videos o ejecutables. Pa dellos valores, dixebrar por comes.

El application/x-www-form-urlencoded codifica de forma automática los valores de tolos elementos del formulariu de la manera variable=valor, dixebraos por &. L'atributu name d'un input suel ser el nome de la variable y la so value el valor. Los espacios reemplazar por + y los calteres non alfanuméricos por $HH onde HH representa'l númberu hexadecimal del calter ASCII.

id=valor+de+la variable&tama%A4o=4

que representáu d'otra forma ye:

id: valor de la variable
tamañu: 4

Procedimientu del restolador

editar

El restolador arrexunta la información del formulariu pa crear el pidimientu y unviala. Les cabeceres unviar xunto al pidimientu POST, y arrexuntar sobre la base de los metatags definíos nel códigu, los automáticos del restolador y los Cookies. Ye'l restolador, tamién, el que codifica los datos si ye necesariu. [ensin referencies]

Funcionamientu

editar
 
Sirvidor

El Sirvidor web executar nun ordenador calteniéndose a la espera de pidimientos per parte d'un veceru (un restolador web) y respuende a estos pidimientos afechiscamente, por aciu una páxina web que se va exhibir nel restolador o amosando'l respeutivu mensaxe si detectóse dalgún error. A manera d'exemplu, al teclear www.wikipedia.org nel nuesu restolador, ésti realiza un pidimientu HTTP al sirvidor de d'estes señes. El sirvidor respuende al veceru unviando'l códigu HTML de la páxina; el veceru, una vegada recibíu'l códigu, interpretar y exhibir en pantalla. Como vemos con esti exemplu, el veceru ye l'encargáu d'interpretar el códigu HTML, esto ye, d'amosar les fontes, los colores y la disposición de los testos y oxetos de la páxina; el sirvidor tan solo llindar a tresferir el códigu de la páxina ensin llevar a cabu nenguna interpretación de la mesma.

Amás de la tresferencia de códigu HTML, los Sirvidores web pueden apurrir aplicaciones web. Estes son porciones de códigu que s'executen cuando se realicen ciertos pidimientos o respuestes HTTP. Hai qu'estremar ente:

  • Aplicaciones nel llau del veceru: el vecera web ye l'encargáu d'executales na máquina del usuariu. Son les aplicaciones tipu Java "applets" o Javascript: el sirvidor apurre'l códigu de les aplicaciones al veceru y ésti, por aciu el restolador, executar. Ye necesariu, por tanto, que'l veceru disponga d'un restolador con capacidá pa executar aplicaciones (tamién llamaes scripts). Comúnmente, el restoladores dexen executar aplicaciones escrites en llinguaxe javascript y java, anque pueden añader más llinguaxes por aciu l'usu de plugins.
  • Aplicaciones nel llau del sirvidor: el sirvidor web executa l'aplicación; ésta, una vegada executada, xenera ciertu códigu HTML; el sirvidor toma esti códigu recién creáu y unviar al veceru per mediu del protocolu HTTP.

Les aplicaciones de sirvidor munches vegaes suelen ser la meyor opción pa realizar aplicaciones web. La razón ye que, al executase ésta nel sirvidor y non na máquina del veceru, ésti nun precisa nenguna capacidá añadida, como sí asocede nel casu de querer executar aplicaciones javascript o java. Con éses cualquier veceru dotáu d'un restolador web básicu puede utilizar esti tipu d'aplicaciones.

El fechu de qu'HTTP y HTML tean íntimamente amestaos nun tien de dar llugar a confundir dambos términos. HTML ye un llinguaxe de marques y HTTP ye un "protocolu".

Aplicación del llau del Sirvidor

editar

Una aplicación del llau del sirvidor ye cualquier programa o conxuntu d'instrucciones diseñaes cola cuenta de qu'un Sirvidor Web procesar pa realizar dalguna aición. Les aplicaciones del llau del sirvidor tán escrites por aciu dalgún llinguaxe de programación, ente los que destaquen:

LlinguaxeFecha de primera versión estableSistema operativuÚltima versión estable
PHP1995Multiplataforma5.6.4
ASP1998Windows (Delles versiones)4.0
Perl1987Multiplataforma5.12.3
Python1991Multiplataforma3.2.0
Ruby1995Multiplataforma1.9.3-p125

El 75% de les aplicaciones del llau del sirvidor tán escrites en PHP, siguíu d'ASP y les demás opciones usaes de forma alternativa y bien casual.[2]

Procesamientu del llau del sirvidor

editar

Un sirvidor web tien la función de procesar los scripts del llau del sirvidor pa dar una salida en HTML y otros llinguaxes del llau del veceru al restolador web del veceru. La información a procesar va poder ser vencida pol veceru al script por aciu cualquier aplicación na redolada del restolador. Pa ello pueden utilizase formulario web, enllaces colos valores implícitos na cadena o cualesquier otru métodu.

 
Rack con sirvidores

Procesamientu de PHP

editar

En PHP esisten variables globales que representen variables y datos de la conexones qu'establez el Sirvidor col veceru.

Métodu GET
editar

Contién toles variables que s'unvien al traviés del métodu HTTP GET, referénciense al traviés del Array unidimensional $_GET['variable']. Esta variable contién el datu unviáu por GET acomuñáu a tal variable, en casu de qu'esista.

Métodu POST
editar

Contién toles variables que s'unvien al traviés del métodu HTTP POST, referénciense al traviés del Array unidimensional $_POST['variable']. Esta variable contién el datu unviáu por POST acomuñáu a tal variable.

Sesiones
editar

Contién datos de sesión adquiríos por aciu un pidimientu GET, POST o la llectura d'una Cookie[ensin referencies]. Referénciase al traviés del Array unidimensional $_SESSION['variable'].Esta variable contién un datu de session.

Cookies
editar

Contién datos sobre toles cookies adquiríes nel pidimientu al server, apurríes pol restolador nel pidimientu HTTP. Referénciase al traviés del Array unidimensional $_COOKIES['variable']

Sirvidor
editar

Contién datos proporcionaos pol Sirvidor Web. Referénciase al traviés del Array unidimensional $_SERVER['variable']

Procesamientu
editar

1) Dau'l siguiente códigu PHP. <html>

if(!empty($_GET['ip']){
if($_GET['ip']=="yes"){
ip();
}}
function ip(){
if ($_SERVER['REMOTE_ADDR']=="192.168.0.1"){
echo "<b>Les sos señes web son 192.168.0.1 </b>";
} else {
echo "<b>Les sos señes web nun son 192.168.0.1 sinón ".$_SERVER['REMOTE_ADDR']."</b>";
}}

</html> Nel casu anterior, podría tomase por supuesta la decisión del usuariu utilizando un enllaz que'l so destino sía l'archivu que contenga'l Script anterior + la variable y el valor utilizando la siguiente sintaxis: archivu.php?var=val onde var ye'l nome d'una variable dada y val ye valor asignáu a la variable.

http://ruta/archivo.php?ip=yes

2) En casu afirmativu'l Script anterior xenera'l siguiente códigu html que ye unviáu darréu al restolador.

<b>Les sos señes web ye 192.168.0.1 </b>

3) El restolador interpreta'l códigu html y amosar similar a :

Les sos señes web ye 192.168.0.1

Sirvidor Web Local

editar

Un Sirvidor Web Local ye aquel Sirvidor Web que mora nuna rede llocal al equipu de referencia. El Sirvidor web Local pue tar instaláu en cualesquier de los equipos que formen parte d'una rede llocal. Ye por tanto obviu, que tolos Sirvidores Web, son locales a la rede llocal na que s'atopen, o a lo menos, locales al sistema nel que tán instalaos.

Cuando un sirvidor Web atópase instaláu nel mesmu equipu dende'l cual deseyar aportar puede utilizase la direición de Loopback, 127.0.0.1 en Ipv4 y ::1 en Ipv6. El puertu TCP 80 resálvase. Los archivos almacenar nun direutoriu determináu pola configuración, xeneralmente modificable.

Esisten numberoses aplicaciones que faciliten la instalación automática de sirvidores web Apache y aplicaciones adicionales como Mysql y PHP (ente otros), de forma conxunta, como XAMPP, JAMP o EasyPHP. Estes aplicaciones reciben el nome de LAMP cuando s'instalen en plataformes Linux, WAMP en sistemes Windows y MAMP en sistemes Apple Macintosh.

Software

editar

Dellos sirvidores web importantes son:

Otru sirvidores, más simples pero más rápidos, son:

Ver tamién

editar

Referencies

editar
  1. «Form enctype».
  2. «1».

Enllaces esternos

editar