4D v14Script del vídeo |
||
|
4D v14
Script del vídeo
Script del vídeo
En este vídeo, vamos a aprender a configurar el servidor web integrado de 4D. La arquitectura integrada de 4D ofrece muchas ventajas ya que con la misma herramienta, con la misma programación, usted puede desarrollar tanto en monopuesto y en cliente/servidor y también publicar en la Web bases de datos sin necesidad de cambiar de herramienta. Para empezar, vamos a verificar el puerto de publicación. En Windows, esto no es útil. En Mac, el puerto 80 es utilizado por defecto por Apache. Así que vamos a configurar este puerto, por ejemplo, en 8080 y luego iniciamos el servidor web (durante la producción, seleccionamos la opción "Lanzar servidor web al inicio de la base" para que sea automático). La página que aparece en el navegador indica que la conexión se ha realizado. Así que vamos a ver lo que sucedió: Ahora nos corresponde a nosotros cambiar el contenido de la página y si es necesario el nombre de la carpeta que contendrá nuestro sitio web (tales como páginas HTML, imágenes, JavaScripts, CSSs). Para hacer más fácil su trabajo, le recomendamos organizar sus archivos de acuerdo a una arquitectura similar a esta:
...donde pueden agrupar los diferentes tipos de archivos en sus carpetas correspondientes. En primer lugar vamos a cambiar la página principal para añadir los datos que provienen de nuestra base de datos (que podrían ser el número de registros por tabla, el contenido de una array, etc.). Pero antes de hacer eso, debemos entender cómo circulan los mensajes entre el navegador y el servidor web de 4D.
Este método recibe un cierto número de parámetros que nos permiten dirigir los procedimientos a realizar y las respuestas a enviar. Supongamos que el navegador solicita:
Pero antes de seguir adelante, vamos a cambiar una de las preferencias de 4D con el fin de elegir, por programación, la página que queremos enviar por defecto:
A partir de ahora, 4D ya no podrá enviar la página automáticamente a menos que primero tomemos el control. Siempre que se realice un cambio en las preferencias, debe detener el servidor web y reiniciarlo. Ahora, vamos a modificar el método "On Web Connection" de manera que envíe la página que queremos. Como todos los métodos 4D, este método recibe parámetros. A continuación podemos probar si el parámetro recibido es "/", y si es así, decidimos enviar una página particular; en este caso la página index.html. C_TEXT($1) Al establecer un punto de ruptura y volver a cargar la página en nuestro navegador, podemos ver que el navegador queda en espera porque el punto de ruptura se ejecutó. Podemos comprobar el parámetro recibido en $1, lo cual es "/", en este caso, vamos a enviar la página index.html. Ahora vamos a modificar nuestra página para mostrar la fecha y hora, así como una lista de todos los técnicos.
Por lo tanto, pretendemos utilizar las variables y los datos de la base. Antes de continuar, es necesario saber que para cada conexión web, se crea un nuevo proceso y por lo tanto las variables y las selecciones de llamadas anteriores no son conservadas por 4D. (En la documentación de 4D, usted aprenderá cómo se manejan las sesiones, lo cual no se trata aquí de modo que podemos centrarnos en entender los mecanismos subyacentes, pero es posible que las variables no siempre se borren, que es el principio de las sesiones). Si volvemos a cargar la página en el navegador, 4D nos indica (ya que se trató de encontrar las variables vdate y vtime) que estas 2 variables no están definidas. Así que tenemos que inicializarlas y asignarles valores antes de recargar la página.. Aquí asignamos los valores a estas 2 variables:
vDate:=Current date Ahora tenemos la fecha y la hora. Antes de enviar la página, podemos crear una selección de técnicos, por ejemplo. ALL RECORDS([Technicians]) Cuando volvemos a cargar la página, por supuesto los técnicos no aparecen, tenemos que añadirlo en el código HTML. Vamos a poner dos saltos de línea luego hacer un bucle en los técnicos e indicar, por ejemplo, que queremos tener el contenido de un campo, será el apellido del técnico con un retorno de carro al final. Al volver a cargar la página, ahora tenemos todos nuestros técnicos. Por supuesto, todos los artificios de visualización HTML (listas, arrays, CSSs, DIVs) se pueden utilizar en la creación de sus páginas. El objetivo de este vídeo es ayudarle a descubrir el fondo, no la forma. Ahora vamos a hacer que podamos hacer clic en cada uno de los técnicos. Para ello, sólo tenemos que guardar y recargar la página y ahora podemos hacer clic en cada técnico. Aquí vemos, en la parte inferior que no se dan detalles porque en HREF no especificamos a dónde debería apuntar este enlace. Depende de nosotros definir que URL aparecerá en 4D, teniendo en cuenta que si queremos pasar sistemáticamente en On Web Connection, la sintaxis de 4D es: (/4DCGI). Si guardamos esto y regresamos, ahora tenemos enlaces en los que se puede hacer clic, sin embargo, no distinguimos entre cada técnico. Así que, después de este URL, debemos indicar el ID del técnico, que asegurará encontrar el correcto. Guardamos y recargamos la página y ahora vemos el ID del técnico al final de cada URL. Vamos a hacer seguimiento para ver qué pasa en 4D cuando hacemos clic en un enlace. En el método On Web Connection, $1 contiene lo que esperamos. De manera que vamos a modificar el método para tener en cuenta esta nueva información. Vamos que $1 puede contener otra cosa más que "/", por ejemplo /4DCGI/@. Por lo tanto estamos en el contexto donde tenemos una llamada estándar al método On Web Connection. Vamos a estructurar esta parte como lo vemos aquí: :($1="/4DCGI/@") //si recibimos un URL destinado a la conexión web Asignamos un valor a una variable intermedia donde remplazamos el 4DCGI; entonces, si la petición enviada es ver un técnico, vamos a cambiar de nuevo la parte que no nos interesa para terminar con el ID que queremos en esta variable. Así que vamos a crear una página intermediaria llamada pagetech.html que contiene el nombre y apellido del técnico y su correo electrónico. Pero primero vamos a ver si podemos obtener este resultado.
Vamos a:
En 4D, cuando continuamos el método, nuestro navegador recibe la información page_tech nformation con el nombre y apellido del técnico. Ahora podemos añadir, en esta página, la lista de las próximas 10 intervenciones a realizar por los técnicos. En el método On Web Connection, antes de enviar la página, sólo debemos añadir:
QUERY([Interventions];[Interventions]Tech_ID=[Technicians]ID) Añadimos un título con un salto de línea si es necesario. Guardamos y cuando volvemos a cargar la página, tenemos la información relativa al técnico, así como también las próximas intervenciones e incluso podemos añadir código HTML más adelante para hacer que la presentación de la página sea un poco más clara. En este punto, también podría proceder de la misma forma para que se pueda hacer clic en cada intervención añadiendo una etiqueta href. Sólo debe guardar los cambios y por supuesto, indicar el URL en el que desea recibir en su servidor web para que cada línea que valla a convertirse en "cliqueable". Esta primera aproximación a una manera rápida y fácil de configurar un sitio web le permite aprender a publicar sus datos en Internet utilizando el motor integrado de 4D. |
PROPIEDADES
Producto: 4D ARTICLE USAGE
Autoformación ( 4D v13) |