Objeto servidor web
Un proyecto 4D puede iniciar y monitorear un servidor web para la aplicación principal (host) así como para cada componente alojado.
Por ejemplo, si ha instalado dos componentes en su aplicación principal, puede iniciar y supervisar hasta tres servidores web independientes desde su aplicación:
- un servidor web para la aplicación local,
- un servidor web para el componente #1,
- un servidor web para el componente #2.
Aparte de la memoria, no hay límite en el número de componentes y por lo tanto, de servidores web, que se pueden adjuntar a un solo proyecto de aplicación 4D.
Cada servidor web 4D, incluido el servidor web de la aplicación principal, se expone como un objeto de la clase 4D.WebServer
. Una vez instanciado, un objeto servidor web puede ser manejado desde la aplicación actual o desde cualquier componente utilizando un gran número de propiedades y funciones.
Los comandos WEB heredados del lenguaje 4D son soportados, pero no se puede seleccionar el servidor web al que se aplican (ver más abajo).
Cada servidor web (aplicación local o componente) puede ser utilizado en su propio contexto independiente, incluyendo:
- las llamadas a los métodos base
On Web Authentication
yOn Web Connection
- el procesamiento de las etiquetas 4D y las llamadas de métodos,
- sesiones web y gestión del protocolo TLS.
Esto le permite desarrollar componentes independientes y funcionalidades que vienen con sus propias interfaces web.
Instanciar un objeto servidor web
El objeto servidor web de la aplicación local (servidor web por defecto) es cargado automáticamente por 4D en al inicio. Por lo tanto, si escribe en un proyecto recién creado:
$nbSrv:=WEB Server list.length
//el valor de $nbSrv es 1
To instantiate a web server object, call the WEB Server
command:
//create an object variable of the 4D.WebServer class
var webServer : 4D.WebServer
//call the web server from the current context
webServer:=WEB Server
//equivalent to
webServer:=WEB Server(Web server database)
Si la aplicación utiliza componentes y quiere llamar a:
- el servidor web de la aplicación local a partir de un componente o
- el servidor que ha recibido la solicitud (sin importar el servidor),
también se puede utilizar:
var webServer : 4D.WebServer
//call the host web server from a component
webServer:=WEB Server(Web server host database)
//call the target web server
webServer:=WEB Server(Web server receiving request)
Funciones del servidor web
Un objeto de clase Web srver contiene las siguientes funciones:
Funciones | Parámetros | Valor devuelto | Descripción |
---|---|---|---|
start() | settings (objet) | status (objeto) | Iniciar el servidor web |
stop() | - | * | Detener el servidor Web |
To start and stop a web server, just call the start()
and stop()
functions of the web server object:
var $status : Object
//to start a web server with default settings
$status:=webServer.start()
//to start the web server with custom settings
//$settings object contains web server properties
webServer.start($settings)
//to stop the web server
$status:=webServer.stop()
Propiedades del servidor web
Un objeto servidor web contiene varias propiedades que configuran el servidor web.
Estas propiedades son definidas:
- using the
settings
parameter of the.start()
function (except for read-only properties, see below), - si no se utiliza, utilizando el comando
WEB SET OPTION
(sólo aplicaciones locales), - si no se utiliza, en los parámetros de la aplicación local o del componente.
- Si el servidor web no se inicia, las propiedades contienen los valores que se utilizarán en el próximo inicio del servidor web.
- If the web server is started, the properties contain the actual values used by the web server (default settings could have been overriden by the
settings
parameter of the.start()
function.
isRunning, name, openSSLVersion, and perfectForwardSecrecy are read-only properties that cannot be predefined in the
settings
object parameter for thestart()
function.
Alcance de los comandos 4D Web
El lenguaje 4D contiene varios comandos permitiendo controlar el servido Web. Sin embargo, estos comandos están diseñados para trabajar con un único servidor web (por defecto). Cuando utilice estos comandos en el contexto de los objetos servidor web, asegúrese de que su alcance es el adecuado.
Comando | Alcance |
---|---|
SET DATABASE PARAMETER | Aplicación local del servidor web |
WEB CLOSE SESSION | Servidor web que ha recibido la petición |
WEB GET BODY PART | Servidor web que ha recibido la petición |
WEB Get body part count | Servidor web que ha recibido la petición |
WEB Get Current Session ID | Servidor web que ha recibido la petición |
WEB GET HTTP BODY | Servidor web que ha recibido la petición |
WEB GET HTTP HEADER | Servidor web que ha recibido la petición |
WEB GET OPTION | Aplicación local del servidor web |
WEB Get server info | Aplicación local del servidor web |
WEB GET SESSION EXPIRATION | Servidor web que ha recibido la petición |
WEB Get session process count | Servidor web que ha recibido la petición |
WEB GET STATISTICS | Aplicación local del servidor web |
WEB GET VARIABLES | Servidor web que ha recibido la petición |
WEB Is secured connection | Servidor web que ha recibido la petición |
WEB Is server running | Aplicación local del servidor web |
WEB SEND BLOB | Servidor web que ha recibido la petición |
WEB SEND FILE | Servidor web que ha recibido la petición |
WEB SEND HTTP REDIRECT | Servidor web que ha recibido la petición |
WEB SEND RAW DATA | Servidor web que ha recibido la petición |
WEB SEND TEXT | Servidor web que ha recibido la petición |
WEB SET HOME PAGE | Aplicación local del servidor web |
WEB SET HTTP HEADER | Servidor web que ha recibido la petición |
WEB SET OPTION | Aplicación local del servidor web |
WEB SET ROOT FOLDER | Aplicación local del servidor web |
WEB START SERVER | Aplicación local del servidor web |
WEB STOP SERVER | Aplicación local del servidor web |
WEB Validate digest | Servidor web que ha recibido la petición |