PDA

Ver la Versión Completa : Servidor web


seoane
26-05-2006, 14:47:33
Bueno, pues voy a poner por aqui otro programita (mas bien un juguete :) ) que hice para pasar el rato, pero me quedo batante bien. Es un pequeño servidor web, creado usando solo funciones de la API (Winsock). Soporta los comando Get y Head, es multihilo, tiene autentificacion, puede listar el contenido de los directorios, etc ...

No intenta tener una utilidad real, pero puede servir para quienes sientan curiosidad por como funciona un servidor web por dentro. Aunque con algunas modificaciones puede resultar un servidor bastante funcional. Por lo de pronto es pequeño :D (solo 98 Kb el ejecutable) de ahi su nombre Pico.

Para probarlo solo hay que ejecutarlo y en un navegador poner esta direccion:

http://127.0.0.1:1978/

Eso deberia mostrar el contenido del directorio raiz. El directorio raiz se puede pasar como primer parametro y la constraseña de acceso como segundo parametro, si se dejan en blanco el directorio raiz sera el raiz del disco y no habra contraseña.

Bueno, no se me ocurre mas que decir, pero si veo que interesa el tema podemos hablar mas en pofundidad.

Sotrono
26-05-2006, 15:31:43
Hola, muchas gracias, le estube "pegando una hojeada" y me parece muy bueno.
Al querer compilarlo me tiro un error en la linea 374:

// Cerramos conexion
if Shutdown(FSocket, SD_SEND) <> SOCKET_ERROR then
repeat until recv(FSocket, buf, sizeof(buf) - 1, 0) <= 0;
CloseSocket(FSocket);

Me dice que el identificador SD_SEND no esta identificado.
Tengo Delphi 5.

Bytes!!

seoane
26-05-2006, 15:34:54
Puede que en esa version de delphi no este definida esa constante, pero eso tiene facil arreglo :)

SD_SEND = 1;

dec
26-05-2006, 16:18:06
Hola,

Tiene una pinta estupenda para estrujarse un poco el cerebro. Muchas gracias Seoane. :D

PatrickM
02-06-2006, 16:39:33
Muy muy currado, me suena a mis dias de universidad con las prácticas de CASO.

Te comento que con el Indy 9 o 10, se puede hacer rapidamente un Servidor Web en pocas lineas de código, o relativamente pocas. Esta claro que lo que has hecho tu es mucho mas pedagógico, pero que ahí tienes los código fuente del Indy por si lo quieres mirar. Ademas ahora supongo que lo querras ampliar para que soporte mas cosas.

En concreto desarrolle un Servidor Web en Indy para la empresa, que daba soporte para WebServices/SOAP, ISAPI i CGI, ademas de servicio de acceso a una Base de Datos aprovechando el tema de SOAP i el DataSnap de Borland.

Las classes principales eran:

TIdHTTPWebBrokerBridge: esta clase viene con el Indy pero no esta en la paleta. Hereda de un TCustomHTTPServer, es decir un Servidor HTTP comun como el que implementas, y lo modifica para ponerle todo el tema Web bien estructurado.

A partir de este le puedes añadir modulos Web del mismo Delphi TWebModule, aprovechando todo el potencial del WebSnap, como por ejemplo el tema de WebServices/SOAP. Después yo encontre por ahi dos classes que funcionan con el TWebModule.

TCGIRunner: Para ejecutar un CGI dentro de un WebModule (da algun problema que otro)

TISAPIRunner: Para ejecutar una libreria dinamica DLL siguiendo el protocolo de Microsoft. Este funciona mejor que el anterior.


Con todo esto consigues un Web Server bastante completito y totalmente propio, con el permiso de Indy Project y demas, claro esta.

No os puedo poner el código porque es propiedad de la empresa, pero creo que con lo que he dado y el Google se puede hacer sin problemas. De hecho la idea la saque de una página de Borland y algun foro.

saludos y enhorabuena por tu Web Server.

seoane
02-06-2006, 18:43:55
PatrickM gracias por tus comentarios. Ya conozco los componentes Indy, los he utilizado en algun proyecto, de echo el componenete idHTTPServer lo utilizaba para generar graficas que luego mostraba en una pagina web. Es indudable que para un proyecto grande y serio son necesarios componetes grandes y serios :) como Indy.

Pero como ya dije este es un juguetito. En mis ratos libres me gusta experimentar, la idea de este servidor surgio cuando intentaba hacer un troyano (solo por experimentar ;) ), los primeros intentos usando componentes generaban ejecutables inmensos y lo que necesitaba era algo mas simple, asi que me fui a la API, lo cree todo haciendo uso solo de funciones de la API y me quedaron unos troyanitos bastante resultones. Lo malo de las aplicaciones Cliente-Servidor es que tienes que hacer el cliente y el servidor :D , asi que para ahorrarme trabajo pense en utilizar un navegador como cliente y que mi servidor actuara como un servidor http. Los troyanos cada vez me quedaban mejor, con capturas de pantalla y demas, llevando los ejecutables al minimo eliminando incluso la unit classes y creando los threads a mano. Pero al final ya no resultaba tan divertido y abandone el proyecto, pero me parecio interesande (didactico si prefieres) colocar la parte del servidor web (solo lo basico) en una aplicacion de consola, y mostrar por pantalla las peticiones http.

Saludos

PatrickM
02-06-2006, 19:04:39
Ah claro, ahora entiendo porque estaba todo hecho en el DPR a saco sin ninguna Unit!! Ya me parecia raro.

dec
01-02-2007, 12:11:07
Hola,

Otra vez yo. Pues nada. Que digo que qué estupendo programa, ¿eh? Qué estupenda práctica... qué curioso... cuántas ideas le surgen a uno tras ver que funciona... tras ver sus potenciales aplicaciones... ¡ay! ¡quién estuviera a tu altura Seoane! :D

PD. Esto lo digo luego de haber revisado un poco más detenidamente a Pico. Cierto que me pierdo no poco (porque de Winsock como que no sé mucho, para qué nos vamos a engañar) pero aún así ha sido un placer. :)

seoane
01-02-2007, 14:54:27
Caramba dec, me vas a hacer sonrojar :o

Aprovecho para preguntar una cosa. Me he fijado que hay, a día de hoy, mas descargas del archivo zip (Pico.zip) que visitas a este tema. ¿Como puede ser? ¿lo han enlazado de forma directa? ¿se puede hacer eso?, si esa es la explicación, me gustaría saber quien lo enlazo y por que, solo por curiosidad.

mamcx
01-02-2007, 15:06:48
Eso es una muy buena idea. En estos dias me arme un servidor web especial para sincronizar unas pocket pc con varios sistemas contables y de erp.

Lo hice usando http://www.realthinclient.eu/index.htm que me lo gane haciendole unas pruebas al creador descargando turboexplorer ;)

Me parecio mas comprensible que Indy.

Lo que mas me gusto es que le integre http://mmm-experts.com/Products.aspx?ProductId=3

La parte pesada la hago con Delphi (y el diseño visual) y el codigo de integracion con python (porque como cosa rara a cada cliente maneja un esquema de base de datos diferente!)

De pronto me animo y hago un articulo de eso.

Lo importante es despertar como ha hecho soane, la idea de lo viable que es Delphi como herramienta para cosas interesantes!

dec
01-02-2007, 15:54:00
Hola,

Nada nada. Al César lo que es del César, como suele decirse.


Aprovecho para preguntar una cosa. Me he fijado que hay, a día de hoy, mas descargas del archivo zip (Pico.zip) que visitas a este tema. ¿Como puede ser? ¿lo han enlazado de forma directa? ¿se puede hacer eso?, si esa es la explicación, me gustaría saber quien lo enlazo y por que, solo por curiosidad.


Pues buscando un poco en Google no parece obtenerse mucha información interesante para el caso. No sé. Lo cierto es que a mí me sorprendió también (y a la vez no me sorprendió) el número de visitas al Hilo esta mañana, pero, no me fijé en el número de descargas de Pico. Que sepas que mías hay unas cuantas, y eso que lo tengo guardado por aquí entre otros "ejemplos". :)

marcoszorrilla
01-02-2007, 16:10:56
Pues me ha gustado mucho el código Seoane, lo primero le damos las gracias por ponerlo en el Foro y a si alguien desarrolla alguna idea más a partir del código que la reporte.

Un Saludo.

dec
01-02-2007, 16:22:16
Hola,


Pues me ha gustado mucho el código Seoane, lo primero le damos las gracias por ponerlo en el Foro y a si alguien desarrolla alguna idea más a partir del código que la reporte.


Yo (que se pare el mundo) he pensado (ya puede echar a andar otra vez) en unir a Pico PHP por motivos evidentes: sería excitante. Pero la verdad es que no tengo ni la más remota idea de por dónde podría empezarse a hacer algo así...

PD. Si alguien diera algunas líneas maestras tal vez alguien lo pensara de nuevo... :D :D

roman
01-02-2007, 17:48:12
Aprovecho para preguntar una cosa. Me he fijado que hay, a día de hoy, mas descargas del archivo zip (Pico.zip) que visitas a este tema. ¿Como puede ser? ¿lo han enlazado de forma directa? ¿se puede hacer eso?, si esa es la explicación, me gustaría saber quien lo enlazo y por que, solo por curiosidad.

Yo veo más visitas al hilo que al zip. Pensé que si daba click varias veces al zip sin salir del hilo podría aumentar las visitas al zip pero al parecer el vBulletin evita las repeticiones.

¿Los demás siguen viendo más visitas al zip?

// Saludos

seoane
01-02-2007, 18:01:07
¿Los demás siguen viendo más visitas al zip?


Ahora ya no, pero hace unas semanas el numero de descargas del zip era mucho mayor que el de visitas. Ahora parece que con las últimas visitas la situación se normalizo. Solo preguntaba por curiosidad, porque me pareció extraño.

mamcx
01-02-2007, 19:03:31
Algo que he visto a pocos hacer es una interface para FastCGI, SCGI y similares.

Un servidor *tan* pequeño tiene dos mercados muy buenos:

- Servidor de contenido estatico. Una excelente manera de aumentar el desempeño de un sitio es servir el contenido estatico (especialmente imagenes, videos, pdfs, etc) con otro servidor.

Lighttpd es el rey en esto

- Interfazar con FastCGI, SCGI y similares. Lighttpd y Mongrel han cogido fuerza en la comunidad de los stacks (Django, turbogears, ruby on rails) porque tiene una carateristica muy buena: Es tan facil como programar CGI, y a la vez no se cargan los interpretes en cada request (una de la razones por las cuales servir contenido estatico con otro servidor web genera tanta ganancia).

Por lo pronto, un servidor de contenido seria genial. Con compresion, seguridad integrada de windows (para manejo de permisos), y poder enviar archivos grandes.

Con eso, ya hay un producto digno del cual hablar!

BlackDaemon
12-04-2007, 20:05:31
Bueno Seoane que mas que decirte que te uniste al grupo de mis ídolos de delphi, :D
Me lo he descargado, lo he compilado y todo bién, esta muy interesante y fácil de usarlo, me sercirá cuando esta fuera de casa, y poder acceder a mi PC y poder descargar algo, bueno y tambien me sirvió para descubrir que tenía un gusano xDD Uno llamado sxs.exe, uno que se transmite via memórias USB, ya pero lo quite :eek:
Con razón no me dejaba abrir mi flash mémory con doble clic, pero ya esta solucionado.

Bueno espero que sigas poniendo códigos así Seoane, la verdad no entiendo mucho , casi nada pues estoy comenzando con delphi, pero en un futuro se que me servirá para tomar un ejemplo de como se hacen ese tipo de aplicaciones, sin mas que decirte FELICITACIONES..

saludos y suerte

Ñuño Martínez
13-04-2007, 13:19:06
(...)bueno y tambien me sirvió para descubrir que tenía un gusano xDD Uno llamado sxs.exe, uno que se transmite via memórias USB, ya pero lo quite :eek: (...) Me ha picado la curiosidad... ¿Cómo lo doscubriste? :confused:

ASAPLTDA
13-04-2007, 17:36:07
Apreciados Foristas,
He leido con atencion sun comentarios sobre el tema del servidor web. :eek:
Pero mis conocimientos son tan basicos que solo caen en la categoria de sin conocimientos.
Creo que muchas personas que trabajamos en Delphi quedamos preocupados por la tendencia del mercado a que muchas aplicaciones requieren que su cliente sea un browser y vemos que no tenemos la habilidad de efectuarlos con delphi, no se si sea desidia o impotencia por la falta de conocimiento, por eso invito a todos a los companeros foristas que habran un espacio de su tiempo, y obsequien a este club los conocimientos para desarrollar aplicaciones web.
La idea es crear una pequena aplicacion hecha en delphi que permiter efectuar mantenimiento, consultas, envio archivos desde una aplicacion web.
Una plan de un desconocedor del tema seria
1. Menu Aplicacion
2. Login solicitud de usuario contraseña , validacion usuario contra el sistema
3. Manejo de Persistencia del usuario conectado y la formas que esta usando
4. Ejecutar programa de Mantenimiento que conste al menos de 3 formas integradas, por ejemplo:
4.1 Solicitud de Codigo a Mantener o ejecutar busque del codigo a mantener
4.2 Forma de Busque del Codigo a Mantener y retornar el codigo buscado
4.3 Ingreso de DAtos del codigo a Mantener y su validacion sin reeingrear los datos (?ajax en la version 3 del modelo)
5. Generacion de Reporte
6. Envio de datos
7. Un web services

Cada una los puntos de llegar a ser validos deben ser documentados de ser posible con pantalla capturadas y explicacion del codigo
El desarrollo del codigo debe ser para DUMMIS :p no empezar con el codigo de delphi net, arrancaquemos con cassini para apreander

Espero que mis colegas no consideren esto una irrespeto por aprovecharme de su tiempo :D lo que realmente pretendo es que los delphianos contemos con una herramienta que nos permita desarrollar software que pueda competir con las aplicaciones hechas en PHP,,,etc . y tener manuales que nos ayuden a tener a delphi como una herramienta competitiva porque encontgramos ejemplos reales y practicos para desarollar aplicaciones y no un ejemplo que no se aplicacable como hola mundo, donde en la vida practica no nos sirve:rolleyes:

BlackDaemon
14-04-2007, 02:11:03
Me ha picado la curiosidad... ¿Cómo lo doscubriste? :confused:

Hola pues como sabes esos gusanos siempre se copian con permisos y ademas invisibles :D y al arir el explorador pude ver claramente todos los ficheros, no se por que, será por que no respeta si está invisible o no, pero por consola cuando hacía d:\dir /w no me lo listaba hasta que le cambie los permisos al ejecutable..
en fin ya lo he quitado http://www.tekkenbolivia.net ese es mi blog y tambien he echo una app en delphi para quitarlo jejeje si quieren el código lo posteo, estoy usando la función de SEOANE para ejecutar comandos en consola cmd

saludos

Ñuño Martínez
16-04-2007, 12:08:16
Espero que mis colegas no consideren esto una irrespeto por aprovecharme de su tiempo :D lo que realmente pretendo es que los delphianos contemos con una herramienta que nos permita desarrollar software que pueda competir con las aplicaciones hechas en PHP,,,etc . y tener manuales que nos ayuden a tener a delphi como una herramienta competitiva porque encontgramos ejemplos reales y practicos para desarollar aplicaciones y no un ejemplo que no se aplicacable como hola mundo, donde en la vida practica no nos sirve:rolleyes:Bueno, con los componentes Indy y la capacidad de Delphi para crear módulos para el servidor web Apache (http://www.apache.org/), pues no recuerdo yo que fuera tan difícil. Más bien al contrario...

Por otro lado, cada cosa para lo que es. Por mucho que nos empeñemos, con Delphi no se puede hacer lo mismo que con PHP... y vicecontra. Son dos herramientas diferentes con objetivos distintos y capacidades diferenciadas. Y para aprender a diseñar programas de red con Delphi tanto este foro como otros sitios de Internet incluyen numerosísima información útil. Sólo tienes que preguntar. :)

frank_
06-11-2007, 19:59:53
Muy muy currado, me suena a mis dias de universidad con las prácticas de CASO.

Te comento que con el Indy 9 o 10, se puede hacer rapidamente un Servidor Web en pocas lineas de código, o relativamente pocas. Esta claro que lo que has hecho tu es mucho mas pedagógico, pero que ahí tienes los código fuente del Indy por si lo quieres mirar. Ademas ahora supongo que lo querras ampliar para que soporte mas cosas.

En concreto desarrolle un Servidor Web en Indy para la empresa, que daba soporte para WebServices/SOAP, ISAPI i CGI, ademas de servicio de acceso a una Base de Datos aprovechando el tema de SOAP i el DataSnap de Borland.

Las classes principales eran:

TIdHTTPWebBrokerBridge: esta clase viene con el Indy pero no esta en la paleta. Hereda de un TCustomHTTPServer, es decir un Servidor HTTP comun como el que implementas, y lo modifica para ponerle todo el tema Web bien estructurado.

A partir de este le puedes añadir modulos Web del mismo Delphi TWebModule, aprovechando todo el potencial del WebSnap, como por ejemplo el tema de WebServices/SOAP. Después yo encontre por ahi dos classes que funcionan con el TWebModule.

TCGIRunner: Para ejecutar un CGI dentro de un WebModule (da algun problema que otro)

TISAPIRunner: Para ejecutar una libreria dinamica DLL siguiendo el protocolo de Microsoft. Este funciona mejor que el anterior.


Con todo esto consigues un Web Server bastante completito y totalmente propio, con el permiso de Indy Project y demas, claro esta.

No os puedo poner el código porque es propiedad de la empresa, pero creo que con lo que he dado y el Google se puede hacer sin problemas. De hecho la idea la saque de una página de Borland y algun foro.

saludos y enhorabuena por tu Web Server.


Hola que tal, de ante mano aclaro que soy nuevo en el tema, tengo una pregunta:

Me he creado varios ISAPI's desde builder6:)
Tambien tengo un servidor http usando la clase TIdHTTPWebBrokerBridge siempre en builder6:)
mi duda es, claro si es que se puede ¿como hacer que mi servidor cargue los ISAPI's (dll's) para que proporcione los servicios que contienen las dll's?:confused: ya que cada ISAPI tiene su propio WebModule y la clase TIdHTTPWebBrokerBridge solo permite cargar uno a la vez:cool:

fide
07-11-2007, 00:43:48
A la verdad que esta cool ese servidor web, y lista los archivos de una forma muy interesante, parecido a los ftps de linux...

PatrickM
07-11-2007, 11:50:36
Hola que tal, de ante mano aclaro que soy nuevo en el tema, tengo una pregunta:

Me he creado varios ISAPI's desde builder6:)
Tambien tengo un servidor http usando la clase TIdHTTPWebBrokerBridge siempre en builder6:)
mi duda es, claro si es que se puede ¿como hacer que mi servidor cargue los ISAPI's (dll's) para que proporcione los servicios que contienen las dll's?:confused: ya que cada ISAPI tiene su propio WebModule y la clase TIdHTTPWebBrokerBridge solo permite cargar uno a la vez

Hola frank,

Yo uso una clase que encontre llamada TISAPIRunner. Tienes que filtrar tu URL para detectar solo aquellas llamadas que hagan referencia a DLL. Despues haces la llamada al ISAPIRunner de esta manera desde el WebModule de tu Servidor Web:



ISAPIRunner.Server:=Programa.ConexionWeb.WebBrokerBridge;
ISAPIRunner.ServerAdmin:='';
ISAPIRunner.Execute(Fichero, TidHTTPappRequest(Request).FThread, TidHTTPAppRequest(Request).FRequestInfo,
TIdHTTPAppResponse(Response).FResponseInfo, ExtractFileDir(ParamStr(0)) + '\Cgi',
True, PathCGI);


Tube que modificar la clase TidHTTPappRequest y TidHTTPResponse, para hacer publicos las variables privadas FThread, FRequestInfo y FResponseInfo.

PathCGI son los parametros de la URL.

frank_
07-11-2007, 16:38:30
Gracias por tu sugerencia PatrickM, ya habia visto esa clase:idISAPIRunner
pero estoy tratrando de cargar los servicios que tengo en las dll's, sin tener que usar esa clase. De todos modos voy a checarlo nuevamente para ver si obtengo alguna idea de como resolver mi problema.

JXJ
19-12-2008, 20:58:44
Eso es una muy buena idea. En estos dias me arme un servidor web especial para sincronizar unas pocket pc con varios sistemas contables y de erp.

Lo hice usando http://www.realthinclient.eu/index.htm que me lo gane haciendole unas pruebas al creador descargando turboexplorer ;)

Me parecio mas comprensible que Indy.

Lo que mas me gusto es que le integre http://mmm-experts.com/Products.aspx?ProductId=3

La parte pesada la hago con Delphi (y el diseño visual) y el codigo de integracion con python (porque como cosa rara a cada cliente maneja un esquema de base de datos diferente!)

De pronto me animo y hago un articulo de eso.

Lo importante es despertar como ha hecho soane, la idea de lo viable que es Delphi como herramienta para cosas interesantes!

mamcx.

¿integrarle python for delphi como le hiciste.?