Objeto objeto incorporado

Enrutamiento de objetos

Objeto de enrutamiento del manejador de mensajes

El objeto de enrutamiento es el objeto central del procesamiento de mensajes http . El servidor coincide con la url y el método de acuerdo con la configuración de enrutamiento, y reenvía el mensaje http al procesador correspondiente para completar diferentes transacciones.

Se puede proporcionar una ruta simple directamente como un objeto JSON, como:

1 2 3 4 5 6 7 8
var http = require('http'); var svr = new http.Server(8080, { '/': r => r.response.write('home'), '/help': r => r.response.write('help') }); svr.run();

Si necesita una personalización de enrutamiento más compleja, puede crear objetos de enrutamiento usted mismo y manejar las políticas de enrutamiento según sea necesario:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
var http = require('http'); var mq = require('mq'); var app = new mq.Routing(); app.get('/', r => r.response.write('home')); app.get('/help', r => r.response.write('help')); app.post('/help', r => r.response.write('post a help.')); app.get('/home/:user', (r, user) => r.response.write('hello ' + user)); app.get('/user/:id(\\d+)', (r, id) => r.response.write('get ' + id)); app.get('/actions', { '/run': r => r.response.write('running'), '/sleep': r => r.response.write('sleeping'), '(.*)': r => r.response.write('........') }); var svr = new http.Server(8080, app); svr.run();

El objeto de enrutamiento coincide con los mensajes de acuerdo con las reglas establecidas y pasa los mensajes al primer procesador que cumple con las reglas. Las reglas de enrutamiento agregadas más tarde coinciden primero. Crear método:

1 2 3 4
var routing = new mq.Routing({ "^/func1(/.*)$": func1, "^/func2(/.*)$": func2 });

Los elementos que coinciden con la expresión regular modifican el atributo de valor del mensaje y los subelementos se almacenan en el atributo params del mensaje. Por ejemplo:

1 2 3
var routing = new mq.Routing({ "^/func1(/([0-9]+)/([0-9]+)\.html)$": func1, });

Después de hacer coincidir el mensaje "/func1/123/456.html", valor == "/123/456.html", params == ["123", "456"];

Si el resultado de la coincidencia no tiene hijos, el valor está vacío y los parámetros están vacíos. Por ejemplo:

1 2 3
var routing = new mq.Routing({ "^/func1/[0-9]+/[0-9]+\.html$": func1, });

Después de hacer coincidir el mensaje "/func1/123/456.html", value == "", params == [];

Si hay varios elementos secundarios en el primer nivel de la coincidencia, el valor está vacío y params es el primer nivel de elementos secundarios. Por ejemplo:

1 2 3
var routing = new mq.Routing({ "^/func1/([0-9]+)/([0-9]+)\.html$": func1, });

Después de hacer coincidir el mensaje "/func1/123/456.html", value == "", params == ["123", "456"];

Si el resultado de la coincidencia tiene un solo hijo y no hay hijos secundarios, tanto el valor como los parámetros son este hijo. Por ejemplo:

1 2 3
var routing = new mq.Routing({ "^/func1/([0-9]+)/[0-9]+\.html$": func1, });

Después de hacer coincidir el mensaje "/func1/123/456.html", valor == "123", params == ["123"];

Herencia

Constructor

Routing

Crear un objeto de enrutamiento de controlador de mensajes

1
new Routing(Object map = {});

Parámetros de llamada:

  • map : objeto, parámetros de ruta de inicialización

Crear un objeto de enrutamiento de controlador de mensajes

1 2
new Routing(String method, Object map);

Parámetros de llamada:

  • method : String, especifica el método de solicitud http , "*" acepta todos los métodos
  • map : objeto, parámetros de ruta de inicialización

Función miembro

append

Agregue una regla desde un objeto de ruta existente. La ruta original se borrará después de agregar.

1
Routing Routing.append(Routing route);

Parámetros de llamada:

  • route : Enrutamiento, el objeto de enrutamiento inicializado

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregar un conjunto de reglas de enrutamiento

1
Routing Routing.append(Object map);

Parámetros de llamada:

  • map : objeto, parámetro de ruta

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregar una regla de enrutamiento

1 2
Routing Routing.append(String pattern, Handler hdlr);

Parámetros de llamada:

  • pattern : Cadena, formato de coincidencia de mensajes
  • hdlr : Handler , el procesador incorporado funciones de procesamiento de mensaje, el encadenamiento de array, objeto de ruta, ver mq.Handler

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregar una regla de enrutamiento

1 2 3
Routing Routing.append(String method, String pattern, Handler hdlr);

Parámetros de llamada:

  • method : String, especifica el método de solicitud http , "*" acepta todos los métodos y "host" especifica el nombre de dominio virtual
  • pattern : Cadena, formato de coincidencia de mensajes
  • hdlr : Handler , el procesador incorporado funciones de procesamiento de mensaje, el encadenamiento de array, objeto de ruta, ver mq.Handler

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

host

Agregar un conjunto de reglas de enrutamiento para nombres de dominio http

1
Routing Routing.host(Object map);

Parámetros de llamada:

  • map : objeto, parámetro de ruta

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregue una regla de enrutamiento que acepte nombres de dominio http

1 2
Routing Routing.host(String pattern, Handler hdlr);

Parámetros de llamada:

  • pattern : Cadena, formato de coincidencia de mensajes
  • hdlr : Handler , el procesador incorporado funciones de procesamiento de mensaje, el encadenamiento de array, objeto de ruta, ver mq.Handler

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

all

Agregue un conjunto de reglas que acepten todos los métodos http

1
Routing Routing.all(Object map);

Parámetros de llamada:

  • map : objeto, parámetro de ruta

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregue una regla de enrutamiento que acepte todos los métodos http

1 2
Routing Routing.all(String pattern, Handler hdlr);

Parámetros de llamada:

  • pattern : Cadena, formato de coincidencia de mensajes
  • hdlr : Handler , el procesador incorporado funciones de procesamiento de mensaje, el encadenamiento de array, objeto de ruta, ver mq.Handler

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

get

Agregue un conjunto de reglas de enrutamiento del método GET

1
Routing Routing.get(Object map);

Parámetros de llamada:

  • map : objeto, parámetro de ruta

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregue una regla de enrutamiento que acepte el método http GET

1 2
Routing Routing.get(String pattern, Handler hdlr);

Parámetros de llamada:

  • pattern : Cadena, formato de coincidencia de mensajes
  • hdlr : Handler , el procesador incorporado funciones de procesamiento de mensaje, el encadenamiento de array, objeto de ruta, ver mq.Handler

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

post

Agregue un conjunto de reglas de enrutamiento que acepten métodos http POST

1
Routing Routing.post(Object map);

Parámetros de llamada:

  • map : objeto, parámetro de ruta

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregue una regla que acepte el método http POST

1 2
Routing Routing.post(String pattern, Handler hdlr);

Parámetros de llamada:

  • pattern : Cadena, formato de coincidencia de mensajes
  • hdlr : Handler , el procesador incorporado funciones de procesamiento de mensaje, el encadenamiento de array, objeto de ruta, ver mq.Handler

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

del

Agregue un conjunto de reglas de enrutamiento que acepten métodos http DELETE

1
Routing Routing.del(Object map);

Parámetros de llamada:

  • map : objeto, parámetro de ruta

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregue una regla de enrutamiento que acepte el método http DELETE

1 2
Routing Routing.del(String pattern, Handler hdlr);

Parámetros de llamada:

  • pattern : Cadena, formato de coincidencia de mensajes
  • hdlr : Handler , el procesador incorporado funciones de procesamiento de mensaje, el encadenamiento de array, objeto de ruta, ver mq.Handler

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

put

Agregue un conjunto de reglas de enrutamiento del método PUT

1
Routing Routing.put(Object map);

Parámetros de llamada:

  • map : objeto, parámetro de ruta

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregue una regla de enrutamiento que acepte el método http PUT

1 2
Routing Routing.put(String pattern, Handler hdlr);

Parámetros de llamada:

  • pattern : Cadena, formato de coincidencia de mensajes
  • hdlr : Handler , el procesador incorporado funciones de procesamiento de mensaje, el encadenamiento de array, objeto de ruta, ver mq.Handler

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

patch

Agregue un conjunto de reglas de enrutamiento del método PATCH

1
Routing Routing.patch(Object map);

Parámetros de llamada:

  • map : objeto, parámetro de ruta

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregue una regla que acepte el método http PATCH

1 2
Routing Routing.patch(String pattern, Handler hdlr);

Parámetros de llamada:

  • pattern : Cadena, formato de coincidencia de mensajes
  • hdlr : Handler , el procesador incorporado funciones de procesamiento de mensaje, el encadenamiento de array, objeto de ruta, ver mq.Handler

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

find

Agregue un conjunto de reglas de enrutamiento del método FIND

1
Routing Routing.find(Object map);

Parámetros de llamada:

  • map : objeto, parámetro de ruta

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

Agregue una regla de enrutamiento que acepte el método http FIND

1 2
Routing Routing.find(String pattern, Handler hdlr);

Parámetros de llamada:

  • pattern : Cadena, formato de coincidencia de mensajes
  • hdlr : Handler , el procesador incorporado funciones de procesamiento de mensaje, el encadenamiento de array, objeto de ruta, ver mq.Handler

Devuelve el resultado:

  • Routing , devuelve el objeto de enrutamiento en sí

invoke

Procesando un mensaje u objeto

1
Handler Routing.invoke(object v) async;

Parámetros de llamada:

  • v : object , especifica el mensaje u objeto a procesar

Devuelve el resultado:

  • Handler , devuelve el siguiente controlador

toString

Devuelve una representación de cadena del objeto, generalmente "[Objeto nativo]". Los objetos se pueden volver a implementar de acuerdo con sus propias características

1
String Routing.toString();

Devuelve el resultado:

  • String , devuelve una representación de cadena del objeto

toJSON

Devuelve una representación JSON del objeto, normalmente devuelve una colección de propiedades legibles definidas por el objeto

1
Value Routing.toJSON(String key = "");

Parámetros de llamada:

  • key : cadena, sin usar

Devuelve el resultado:

  • Value , devuelve un valor que contiene un JSON serializable