Oggetto oggetto incorporato

Instradamento degli oggetti

Oggetto di instradamento del gestore dei messaggi

L'oggetto routing è http L'oggetto principale dell'elaborazione dei messaggi, il server corrisponde in base all'impostazione di routing url E metodo, e http Il messaggio viene inoltrato al processore corrispondente per completare diverse transazioni.

Un percorso semplice può essere fornito direttamente sotto forma di oggetto JSON, come:

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.start();

Se hai bisogno di una personalizzazione del routing più complessa, puoi creare tu stesso l'oggetto Routing ed elaborare la strategia di routing secondo necessità:

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.start();

L'oggetto di routing corrisponde al messaggio in base alle regole impostate e consegna il messaggio al primo processore che soddisfa le regole. Le regole di instradamento aggiunte in seguito vengono abbinate per prime. Metodo di creazione:

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

Gli elementi corrispondenti all'espressione regolare modificano l'attributo value del messaggio e gli elementi secondari vengono memorizzati nell'attributo params del messaggio. Per esempio:

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

Dopo aver trovato il messaggio "/func1/123/456.html", value == "/123/456.html", params == ["123", "456"];

Se il risultato della corrispondenza non ha figli, value è vuoto e params è vuoto. Per esempio:

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

Dopo aver trovato il messaggio "/func1/123/456.html", value == "", params == [];

Se il risultato della corrispondenza ha più elementi secondari nel primo livello, il valore è vuoto e params sono gli elementi secondari di primo livello. Per esempio:

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

Dopo aver trovato il messaggio "/func1/123/456.html", value == "", params == ["123", "456"];

Se il risultato della corrispondenza ha solo un elemento secondario e nessun elemento secondario, valore e parametri sono entrambi questo elemento secondario. Per esempio:

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

Dopo aver trovato il messaggio "/func1/123/456.html", value == "123", params == ["123"];

Eredità

#lineWidth: 1.5 #font: Helvetica,sans-Serif #fontSize: 10 #leading: 1.6 #.this: fill=lightgray #.class: fill=white [<class>object|toString();toJSON()] [<class>Handler|new Handler()|invoke()] [<this>Routing|new Routing()|append();host();all();get();post();del();put();patch();find()] [object] <:- [Handler] [Handler] <:- [Routing] Handler new Handler() invoke() Routing new Routing() append() host() all() get() post() del() put() patch() find() object toString() toJSON()

Costruttore

Routing

Crea un oggetto di instradamento del gestore dei messaggi

1
new Routing(Object map = {});

Parametri di chiamata:

  • map: Oggetto, inizializza i parametri di routing

Crea un oggetto di instradamento del gestore dei messaggi

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

Parametri di chiamata:

  • method: Stringa, specifica http Metodo di richiesta, "*" accetta tutti i metodi
  • map: Oggetto, inizializza i parametri di routing

Funzione membro

append

Aggiungi una regola da un oggetto percorso esistente, il percorso originale verrà cancellato dopo l'aggiunta

1
Routing Routing.append(Routing route);

Parametri di chiamata:

  • route: Routing, l'oggetto di routing che è stato inizializzato

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi una serie di regole di instradamento

1
Routing Routing.append(Object map);

Parametri di chiamata:

  • map: Oggetto, parametri di routing

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi una regola di instradamento

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

Parametri di chiamata:

  • pattern: Stringa, formato di corrispondenza del messaggio
  • hdlr: Handler, Processore di messaggi integrato, funzione di elaborazione, matrice di elaborazione della catena, oggetto di routing, vedere i dettagli mq.Handler

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi una regola di instradamento

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

Parametri di chiamata:

  • method: Stringa, specifica http Metodo di richiesta, "*" accetta tutti i metodi, "host" specifica il nome del dominio virtuale
  • pattern: Stringa, formato di corrispondenza del messaggio
  • hdlr: Handler, Processore di messaggi integrato, funzione di elaborazione, matrice di elaborazione della catena, oggetto di routing, vedere i dettagli mq.Handler

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

host

Aggiungi un gruppo http Regole di instradamento dei nomi di dominio

1
Routing Routing.host(Object map);

Parametri di chiamata:

  • map: Oggetto, parametri di routing

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi un'accettazione http Regole di instradamento dei nomi di dominio

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

Parametri di chiamata:

  • pattern: Stringa, formato di corrispondenza del messaggio
  • hdlr: Handler, Processore di messaggi integrato, funzione di elaborazione, matrice di elaborazione della catena, oggetto di routing, vedere i dettagli mq.Handler

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

all

Aggiungi un gruppo per accettare tutto http Regole di instradamento del metodo

1
Routing Routing.all(Object map);

Parametri di chiamata:

  • map: Oggetto, parametri di routing

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi uno accetta tutto http Regole di instradamento del metodo

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

Parametri di chiamata:

  • pattern: Stringa, formato di corrispondenza del messaggio
  • hdlr: Handler, Processore di messaggi integrato, funzione di elaborazione, matrice di elaborazione della catena, oggetto di routing, vedere i dettagli mq.Handler

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

get

Aggiungi una serie di regole di instradamento del metodo GET

1
Routing Routing.get(Object map);

Parametri di chiamata:

  • map: Oggetto, parametri di routing

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi un'accettazione http Regole di instradamento del metodo GET

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

Parametri di chiamata:

  • pattern: Stringa, formato di corrispondenza del messaggio
  • hdlr: Handler, Processore di messaggi integrato, funzione di elaborazione, matrice di elaborazione della catena, oggetto di routing, vedere i dettagli mq.Handler

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

post

Aggiungi un gruppo per accettare http Regole di instradamento del metodo POST

1
Routing Routing.post(Object map);

Parametri di chiamata:

  • map: Oggetto, parametri di routing

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi un'accettazione http Regole di instradamento del metodo POST

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

Parametri di chiamata:

  • pattern: Stringa, formato di corrispondenza del messaggio
  • hdlr: Handler, Processore di messaggi integrato, funzione di elaborazione, matrice di elaborazione della catena, oggetto di routing, vedere i dettagli mq.Handler

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

del

Aggiungi un gruppo per accettare http Regole di instradamento del metodo DELETE

1
Routing Routing.del(Object map);

Parametri di chiamata:

  • map: Oggetto, parametri di routing

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi un'accettazione http Regole di instradamento del metodo DELETE

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

Parametri di chiamata:

  • pattern: Stringa, formato di corrispondenza del messaggio
  • hdlr: Handler, Processore di messaggi integrato, funzione di elaborazione, matrice di elaborazione della catena, oggetto di routing, vedere i dettagli mq.Handler

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

put

Aggiungi una serie di regole di instradamento del metodo PUT

1
Routing Routing.put(Object map);

Parametri di chiamata:

  • map: Oggetto, parametri di routing

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi un'accettazione http Regole di instradamento del metodo PUT

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

Parametri di chiamata:

  • pattern: Stringa, formato di corrispondenza del messaggio
  • hdlr: Handler, Processore di messaggi integrato, funzione di elaborazione, matrice di elaborazione della catena, oggetto di routing, vedere i dettagli mq.Handler

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

patch

Aggiungi un set di regole di routing del metodo PATCH

1
Routing Routing.patch(Object map);

Parametri di chiamata:

  • map: Oggetto, parametri di routing

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi un'accettazione http Regole di instradamento del metodo PATCH

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

Parametri di chiamata:

  • pattern: Stringa, formato di corrispondenza del messaggio
  • hdlr: Handler, Processore di messaggi integrato, funzione di elaborazione, matrice di elaborazione della catena, oggetto di routing, vedere i dettagli mq.Handler

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

find

Aggiungi una serie di regole di instradamento del metodo FIND

1
Routing Routing.find(Object map);

Parametri di chiamata:

  • map: Oggetto, parametri di routing

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

Aggiungi un'accettazione http Trova le regole di instradamento del metodo

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

Parametri di chiamata:

  • pattern: Stringa, formato di corrispondenza del messaggio
  • hdlr: Handler, Processore di messaggi integrato, funzione di elaborazione, matrice di elaborazione della catena, oggetto di routing, vedere i dettagli mq.Handler

Risultato di ritorno:

  • Routing, Restituisce l'oggetto del percorso stesso

invoke

Elabora un messaggio o un oggetto

1
Handler Routing.invoke(object v) async;

Parametri di chiamata:

  • v: object, Specificare il messaggio o l'oggetto da elaborare

Risultato di ritorno:

  • Handler, Torna al processore successivo

toString

Restituisce la rappresentazione in stringa dell'oggetto, generalmente restituisce "[Native Object]", l'oggetto può essere re-implementato secondo le proprie caratteristiche

1
String Routing.toString();

Risultato di ritorno:

  • String, Restituisce la rappresentazione di stringa dell'oggetto

toJSON

Restituisce la rappresentazione in formato JSON dell'oggetto, generalmente restituisce una raccolta di attributi leggibili definiti dall'oggetto

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

Parametri di chiamata:

  • key: Stringa, inutilizzata

Risultato di ritorno:

  • Value, Restituisce un valore contenente JSON serializzabile