Tipu | funcionalidá de software y tipu de software |
---|---|
Etiqueta de Stack Exchange | Stack Exchange |
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.
Arquiteutura
Pidimientu GET
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
Pidimientu Web
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
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
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é
Á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é
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
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
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
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
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
Estructura típica d'un pidimientu POST |
Amuesa |
|
Petition type |
|
|
Referer |
|
|
Content-Length |
|
|
Origin |
|
|
User-Agent |
|
|
Content-Type |
|
|
Accept |
|
|
Accept-Language |
|
|
Accept-Charset |
|
|
Cookie |
|
|
Accept-Encoding |
|
|
Content |
|
|
Composición d'un pidimientu POST
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
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
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
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
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
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:
Llinguaxe | Fecha de primera versión estable | Sistema operativu | Última versión estable |
PHP | 1995 | Multiplataforma | 5.6.4 |
ASP | 1998 | Windows (Delles versiones) | 4.0 |
Perl | 1987 | Multiplataforma | 5.12.3 |
Python | 1991 | Multiplataforma | 3.2.0 |
Ruby | 1995 | Multiplataforma | 1.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
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.
Procesamientu de PHP
En PHP esisten variables globales que representen variables y datos de la conexones qu'establez el Sirvidor col veceru.
Métodu GET
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
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
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
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
Contién datos proporcionaos pol Sirvidor Web. Referénciase al traviés del Array unidimensional $_SERVER['variable']
Procesamientu
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
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
Dellos sirvidores web importantes son:
- Nginx
- Apache
- Internet Information Services (IIS)
- Cherokee
- Tomcat
Otru sirvidores, más simples pero más rápidos, son:
- lighttpd
- thttpd
Ver tamién
Referencies
- ↑ «Form enctype».
- ↑ «1».
Enllaces esternos