• Share
  • Email
  • Embed
  • Like
  • Save
  • Private Content
Node.js: aspecte esențiale
 

Node.js: aspecte esențiale

on

  • 1,218 views

Essential aspects regarding server-side Web development by using Node.js (available in Romanian)

Essential aspects regarding server-side Web development by using Node.js (available in Romanian)

Statistics

Views

Total Views
1,218
Views on SlideShare
959
Embed Views
259

Actions

Likes
1
Downloads
7
Comments
0

2 Embeds 259

http://busaco.wordpress.com 258
https://busaco.wordpress.com 1

Accessibility

Categories

Upload Details

Uploaded via as Adobe PDF

Usage Rights

CC Attribution-NonCommercial-ShareAlike LicenseCC Attribution-NonCommercial-ShareAlike LicenseCC Attribution-NonCommercial-ShareAlike License

Report content

Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
  • Full Name Full Name Comment goes here.
    Are you sure you want to
    Your message goes here
    Processing…
Post Comment
Edit your comment

    Node.js: aspecte esențiale Node.js: aspecte esențiale Presentation Transcript

    • Tehnologii Web Dr. Sabin Buragawww.purl.org/net/busacoProgramare Web – supliment node.js: aspecte esentiale
    • Dr. Sabin Buragawww.purl.org/net/busaco“Cine a vazut vreodata o bijuterie frumos cizelata de bijutier cu ajutorul ciocanului?” Jan Amos Comenius
    • node.js: (pre)istoric Dr. Sabin Buragawww.purl.org/net/busaco Brendan Eich dezvolta limbajul JavaScript (1995)JavaScript inclus in browser-ul Netscape Navigator (1996)Netscape propune Livewire – JS la nivel de server (1996)  prima editie a standardului ECMAScript (1997)
    • node.js: (pre)istoric Dr. Sabin Buragawww.purl.org/net/busaco Microsoft include obiectul XMLHttpRequest (1999) transfer asincron via Ajax (2005) JSON – JavaScript Object Notation (2000) format simplist pentru interschimb de date aparitia bibliotecii jQuery (2005)abstractizeaza & simplifica manipularea paginilor WebJS (ActionScript) pentru Adobe Creative Suite (2005)
    • node.js: (pre)istoric Dr. Sabin Buragawww.purl.org/net/busacoJavaScript in contextul bazelor de date – CouchDB (2006) Apple ofera WebKit bazat pe KHTML de la KDE (2007) disponibil in regim open source la www.webkit.org Google Chrome – cod JS performant via V8 (2008) ofera premisele crearii de aplicatii Web complexe rulate in cadrul navigatorului Web documentatii de referinta oferite de Mozilla (2011) http://developer.mozilla.org/
    • node.js: istoric Dr. Sabin Buragawww.purl.org/net/busaco Ryan Dahl creeaza Node.js (2009) http://nodejs.org/Node.js ruleaza pe masini respectand standardul POSIX + pe calculatoare Windows (2011) Node.js este adoptat de industriee.g., Cloud9 IDE, eBay, LinkedIn, Storify, Yahoo! (2012) Node.js 0.10 – versiunea actuala (2013)
    • node.js: caracterizare Dr. Sabin Buragawww.purl.org/net/busaco“Node.js is a platform built on Chrome’s JavaScript runtime for easily building fast, scalable network applications. Node.js uses an event-driven,non-blocking I/O model that makes it lightweight and efficient, perfect for data-intensive real-time applications that run across distributed devices.”
    • node.js: caracterizare Dr. Sabin Buragawww.purl.org/net/busaco Permite dezvoltarea de aplicatii Webla nivel de server in limbajul JavaScriptrecurge la V8 – procesor (interpretor) JavaScript creat de Google si disponibil liber https://code.google.com/p/v8/
    • node.js: caracterizare Dr. Sabin Buragawww.purl.org/net/busacoOfera suport pentru cele mai importante protocoale Web si Internet HTTP (HyperText Transfer Protocol) DNS (Domain Name System) TLS (Transport Layer Security)functionalitati de nivel scazut (socket-uri TCP)
    • node.js: caracterizare Dr. Sabin Buragawww.purl.org/net/busaco Operatiile de intrare/iesire sunt asincrone fiecare cerere (operatie) adresata aplicatiei noastre– e.g., acces la disc, la retea, la alt proces – poate aveaatasata o functie de tratare a unui eveniment specific evented I/O
    • cod JS executat de cod JS rulat pe partea client (browser Web) de server (node.js) procesare Dr. Sabin Buragawww.purl.org/net/busaco asteapta si trateaza evenimente de bazata pe asteapta si trateaza interactiune evenimente cereri (evenimente) (onclick, onmouseover, evented/ provenite de la client(i) onkeypressed,…) event-basedprogramul trebuie sa fie programul trebuie sa fie responsiv atunci cand responsiv atunci cand asteapta incarcarea asincronism asteapta incarcarea datelor de pe retea (e.g., operatii datelor locale/externe(e.g., JSON, XML, imagini, neblocante) (provenite din baze de video) via Ajax/Comet date, fisiere, ori socket-uri Web servicii Web, API-uri,…) adaptare dupa Ben Sheldon (2012): http://www.island94.org/?p=3066
    • node.js: caracterizare Dr. Sabin Buragawww.purl.org/net/busacoO aplicatie node.js ruleaza intr-un singur proces codul JavaScript nu este executat paralel, dar trateaza in mod asincron diverse evenimente I/O single-process event loop
    • node.js: caracterizare Dr. Sabin Buragawww.purl.org/net/busacoO aplicatie node.js ruleaza intr-un singur proces deosebire esentiala fata de serverele de aplicatii Webtraditionale ce recurg la servere multi-process/threaded
    • node.js: caracterizare Dr. Sabin Buragawww.purl.org/net/busacoO aplicatie node.js ruleaza intr-un singur proces server tipic server node.jsadaptare dupa Ben Sheldon (2012): http://www.island94.org/?p=3066
    • node.js: caracterizare Dr. Sabin Buragawww.purl.org/net/busaco Mediul node.js e disponibil gratuit – open source –pentru platformele UNIX/Linux, Windows, Mac OS X http://nodejs.org/download/
    • functionalitatilesuplimentare sunt oferite de module administrate Dr. Sabin Buragawww.purl.org/net/busaco via npm https://npmjs.org/
    • node.js: caracterizare Dr. Sabin Buragawww.purl.org/net/busacoOfera un mediu de executie in linia de comanda,pe baza unor biblioteci C++ si a procesorului V8 (infoiasi)$ node program.js
    • node.js: exemplu Dr. Sabin Buragawww.purl.org/net/busaco Un prim program care emite saluturi// salutari.js: un program (de sine-statator) care emite un salutconsole.log (Salutari banale din Node.js); invocarea unei metode oferita de un obiect predefinit
    • node.js: exemplu Dr. Sabin Buragawww.purl.org/net/busaco Un prim program care emite saluturi// salutari.js: un program (de sine-statator) care emite un salutconsole.log (Salutari banale din Node.js);(infoiasi)$ node salutari.jsSalutari banale din Node.js
    • // Un program JavaScript care saluta toti posibilii sai clienti Webvar http = require (http); // folosim http, un modul Node predefinithttp.createServer ( // cream un server Web Dr. Sabin Buragawww.purl.org/net/busaco // functie anonima ce trateaza o cerere si trimite un raspuns function (cerere, raspuns) { // afisam la consola serverului mesaje de diagnostic console.log (Am primit o cerere...); // stabilim valori pentru diverse campuri-antet HTTP raspuns.writeHead (200, { Content-Type: text/html }); // emitem raspunsul propriu-zis conform tipului MIME (cod HTML) raspuns.end (<html><body><h1>Salutari…</h1></body></html>); } // serverul asculta cereri la portul 8080 al masinii locale ).listen (8080, "127.0.0.1");console.log (Serverul creat asteapta cereri la http://127.0.0.1:8080/);
    • programul JavaScript creat functioneaza ca un server Webpentru fiecare cerere emisa de un posibil client (browser, aplicatie desktop etc.) conform modelului client/server Dr. Sabin Buragawww.purl.org/net/busaco pe partea de server – asteptare cereri(infoiasi)$ node salutari-web.jsServerul creat asteapta cereri la http://127.0.0.1:8080/Am primit o cerere...Am primit o cerere...
    • programul JavaScript creat functioneaza ca un server Webpentru fiecare cerere emisa de un posibil client (browser, aplicatie desktop etc.) conform modelului client/server Dr. Sabin Buragawww.purl.org/net/busaco pe partea de server – asteptare cereri(infoiasi)$ node salutari-web.jsServerul creat asteapta cereri la http://127.0.0.1:8080/Am primit o cerere...Am primit o cerere... la client – receptionare raspuns conform cererii GET emise de un program desktop si de un navigator Web(infoiasi)$ node client-salutari.jsAm primit raspuns de la server -- cod HTTP: 200Continut receptionat: <html><body><h1>Salutari din Node.js</h1></body></html>
    • // Un program JS care implementeaza un client pentru serviciul de salutvar http = require (http);http.get (http://127.0.0.1:8080/, // emite o cerere HTTP Dr. Sabin Buragawww.purl.org/net/busaco function (raspuns) { console.log (Am primit raspuns de la server -- cod HTTP: + raspuns.statusCode); // statusCode: 200, 404,… })// tratam diverse evenimente.on (error, // eroare function (e) { console.log (Eroare: + e.message); }).on (response, // receptare raspuns de la server function (raspuns) { // exista date de procesat raspuns.on (data, function (date) { console.log (Continut receptionat: + date); }); });
    • node.js: module Dr. Sabin Buragawww.purl.org/net/busacoFunctia require () specifica utilizarea unui modul Node.js module predefinite (built-in): privitoare la Web – http, https, url, querystring referitoare la fisiere – fs, path vizand reteaua – net, dns, dgram, tls,resurse privind sistemul de operare – os, child_process alte aspecte de interes – buffer, console, util, crypto
    • node.js: module – http Dr. Sabin Buragawww.purl.org/net/busacoDezvoltarea de aplicatii Web via modulul http functionalitati HTTP de baza crearea unui server Web: createServer() realizarea de cereri HTTP: request() get()
    • node.js: module – http Dr. Sabin Buragawww.purl.org/net/busacoDezvoltarea de aplicatii Web via modulul http servire de cereri HTTP – clasa http.Server metode uzuale: listen() setTimeout() close() evenimente ce pot fi tratate: request connect close clientError etc.
    • node.js: module – http Dr. Sabin Buragawww.purl.org/net/busaco Dezvoltarea de aplicatii Web via modulul httpraspuns emis de server – clasa http.ServerResponse metode uzuale: writeHead() getHeader() removeHeader() write() end() etc. evenimente: close clientError proprietati folositoare: statusCode headersSent
    • node.js: module – http Dr. Sabin Buragawww.purl.org/net/busaco Dezvoltarea de aplicatii Web via modulul httpcerere emisa de client – clasa http.ClientRequest metode uzuale:write() abort() end() setTimeout() setSocketKeepAlive() etc. evenimente ce pot fi tratate: response connect continue socket etc.
    • node.js: module – http Dr. Sabin Buragawww.purl.org/net/busacoDezvoltarea de aplicatii Web via modulul httpmesaj vehiculat – clasa http.IncomingMessagemetode: setEncoding() setTimeout() pause() resume() evenimente ce pot fi tratate: data end close proprietati de interes: httpVersion headers method url statusCode socket
    • node.js: module – url Dr. Sabin Buragawww.purl.org/net/busacoProcesarea adreselor Web via modulul url metode oferite: parse() format() resolve() http://nodejs.org/api/url.html
    • var url = require (url); Dr. Sabin Buragawww.purl.org/net/busacovar adresaWeb = url.parse ( http://undeva.info:8080/oferta/jucarii/produs/?nume=Tux&marime=17#descriere, true // genereaza un obiect query ce include campurile din querystring);console.log (adresaWeb);if (adresaWeb[query].marime > 13) { console.log (Jucaria e in regula.);} else { console.log (Jucaria e stricata.);}
    • (infoiasi)$ node url.js{ protocol: http:, Dr. Sabin Buragawww.purl.org/net/busaco slashes: true, auth: null, host: undeva.info:8080, port: 8080, hostname: undeva.info, hash: #descriere, search: ?nume=Tux&marime=17, query: { nume: Tux, marime: 17 }, pathname: /oferta/jucarii/produs/, path: /oferta/jucarii/produs/?nume=Tux&marime=17, href: http://undeva.info:8080/oferta/jucarii/produs/?nume=…}Jucaria e in regula.
    • node.js: module – net Dr. Sabin Buragawww.purl.org/net/busacoCrearea de aplicatii Internet – modulul net partea de server: createServer() + clasa net.Servermetode: listen() close() address() getConnections() evenimente: listening connection close error
    • node.js: module – net Dr. Sabin Buragawww.purl.org/net/busacoCrearea de aplicatii Internet – modulul net partea de client: connect() createConnection()
    • node.js: module – net Dr. Sabin Buragawww.purl.org/net/busaco Crearea de aplicatii Internet – modulul net acces la socket-uri – clasa net.Socket metode: connect() write() setEncoding() destroy() end() etc. evenimente: connect data end timeout drain error close proprietati utile: localAddress localPortremoteAddress remotePort bytesRead bytesWritten bufferSize
    • node.js: module – fs Dr. Sabin Buragawww.purl.org/net/busacoAcces la sistemul de fisiere via modulul fs metode folosite uzual: open() read() write() close() truncate() stat() chmod() rename() isFile() isDirectory() isSocket()
    • Dr. Sabin Buragawww.purl.org/net/busacopentru detalii, a se consulta documentatia oficiala in acest caz, vezi http://nodejs.org/api/fs.html
    • node.js: module – fs Dr. Sabin Buragawww.purl.org/net/busaco Acces la sistemul de fisiere via modulul fs studiu de caz (Victor Porof, 2013): generare de liste de melodii via iTunes si Last.fm https://github.com/victorporof/plgen(ilustreaza si maniera de creare a modulelor proprii)
    • node.js: fluxuri de date Dr. Sabin Buragawww.purl.org/net/busaco Accesul la date poate fi realizat prin intermediul fluxurilor (streams) abstractizeaza accesul la date stocate partial (partially buffered data)emit evenimente ce pot fi tratate de codul aplicatiei
    • node.js: fluxuri de date Dr. Sabin Buragawww.purl.org/net/busaco Accesul la date poate fi realizat prin intermediul fluxurilor (streams) fluxuri ce pot fi citite (readable streams)e.g., create de fs.createReadStream() http.ServerRequesthttp.ClientResponse net.Socket child.stdout process.stdin
    • node.js: fluxuri de date Dr. Sabin Buragawww.purl.org/net/busaco Accesul la date poate fi realizat prin intermediul fluxurilor (streams) fluxuri ce pot fi citite (readable streams)e.g., create de fs.createReadStream() http.ServerRequesthttp.ClientResponse net.Socket child.stdout process.stdin emit evenimentele data end error
    • node.js: fluxuri de date Dr. Sabin Buragawww.purl.org/net/busaco Accesul la date poate fi realizat prin intermediul fluxurilor (streams) fluxuri ce pot fi citite (readable streams)e.g., create de fs.createReadStream() http.ServerRequesthttp.ClientResponse net.Socket child.stdout process.stdin au asociate metodele pause() resume() destroy()
    • node.js: fluxuri de date Dr. Sabin Buragawww.purl.org/net/busaco Accesul la date poate fi realizat prin intermediul fluxurilor (streams) fluxuri ce pot fi scrise (writeable streams)e.g., create de fs.createWriteStream() http.ServerResponse http.ClientRequest net.Socket child.stdin process.stdout
    • node.js: fluxuri de date Dr. Sabin Buragawww.purl.org/net/busaco Accesul la date poate fi realizat prin intermediul fluxurilor (streams) fluxuri ce pot fi scrise (writeable streams)e.g., create de fs.createWriteStream() http.ServerResponse http.ClientRequest net.Socket child.stdin process.stdout emit evenimentele drain error
    • node.js: fluxuri de date Dr. Sabin Buragawww.purl.org/net/busaco Accesul la date poate fi realizat prin intermediul fluxurilor (streams) fluxuri ce pot fi scrise (writeable streams)e.g., create de fs.createWriteStream() http.ServerResponse http.ClientRequest net.Socket child.stdin process.stdout ofera metodele write() end() destroy()
    • // Program ce preia ceea ce tasteaza utilizatorul la intrarea standard// si scrie intr-un fisier – conform M. Takada (2012)var fs = require (fs); Dr. Sabin Buragawww.purl.org/net/busacovar fisier = fs.createWriteStream (./spion.txt);// la aparitia datelor, le scriem in fisierprocess.stdin.on (data, function (date) { fisier.write (date); } );// tratam evenimentul de terminare a fluxuluiprocess.stdin.on (end, function() { fisier.end (); } );// "reactivam" intrarea standard; implicit, e in starea pausedprocess.stdin.resume (); obiectul process e global – detalii la http://nodejs.org/api/process.html
    • node.js: rulare temporizata Dr. Sabin Buragawww.purl.org/net/busacoSe poate planifica executia codului JavaScript recurgerea la functiile globale setTimeout () clearTimeout () setInterval () clearInterval()
    • // cream un server Web care trimite fiecarui client secventa valorilor unui contorvar server = http.createServer ().listen (8080, 127.0.0.1);// stabilim un comportament la aparitia evenimentului request (cerere de la un client) Dr. Sabin Buragawww.purl.org/net/busacoserver.on (request, function (cerere, raspuns) { console.log (Cerere de la clientul + cerere.headers[user-agent]); raspuns.writeHead (200, { Content-Type: text/html }); var contor = 0; var interval = setInterval ( // generam valori ale contorului conform intervalului de timp function () { raspuns.write (<p>Contorul are valoarea + contor + </p>); console.log (Contorul are valoarea + contor); contor++; if (contor >= 7) { clearInterval (interval); // stergem intervalul raspuns.end (); // inchidem fluxul de raspuns console.log (Am trimis raspuns clientului + cerere.headers[user-agent]); } }, 1000); // cod rulat la interval de 1000 milisec.});
    • Cerere de la clientul … Gecko/20100101 Firefox/19.0Contorul are valoarea 0Contorul are valoarea 1Contorul are valoarea 2 Dr. Sabin Buragawww.purl.org/net/busacoContorul are valoarea 3Cerere de la clientul (… MSIE 10.0; Windows NT 6.1; Trident/6.0)Contorul are valoarea 4Contorul are valoarea 0 codul este rulatContorul are valoarea 5Contorul are valoarea 1 asincronContorul are valoarea 6Am trimis raspuns clientului … Gecko/20100101 Firefox/19.0Contorul are valoarea 2Contorul are valoarea 3Contorul are valoarea 4Contorul are valoarea 5Contorul are valoarea 6Am trimis raspuns clientului (… MSIE 10.0; Windows NT 6.1; Trident/6.0)
    • Cerere de la clientul … Gecko/20100101 Firefox/19.0Contorul are valoarea 0Contorul are valoarea 1Contorul are valoarea 2 Dr. Sabin Buragawww.purl.org/net/busacoContorul are valoarea 3Cerere de la clientul (… MSIE 10.0; Windows NT 6.1; Trident/6.0)Contorul are valoarea 4Contorul are valoarea 0Contorul are valoarea 5Contorul are valoarea 1Contorul are valoarea 6Am trimis raspuns clientului … Gecko/20100101 Firefox/19.0Contorul are valoarea 2Contorul are valoarea 3Contorul are valoarea 4Contorul are valoarea 5Contorul are valoarea 6Am trimis raspuns clientului (… MSIE 10.0; Windows NT 6.1; Trident/6.0) browser-ul va astepta ca intreaga secventa de valori de ce? sa fie trimisa de catre server
    • node.js: evenimente Dr. Sabin Buragawww.purl.org/net/busacoEmiterea (lansarea) si tratarea (prinderea)evenimentelor specificate de programator se realizeaza via event.EventEmitterclasa utilizata intern de multe biblioteci de baza http://nodejs.org/api/events.html
    • node.js: module externe Dr. Sabin Buragawww.purl.org/net/busacoFunctia require () specifica utilizarea unui modul Node.jsmodule disponibile on-line (instalate via utilitarul npm) instalare globala a unui modul: npm install modul –g listarea modulelor existente: npm list cautarea unui modul: npm search modul eliminarea unui modul: npm uninstall modul actualizarea unui modul: npm update modul
    • node.js: module – node-sqlite-purejs Dr. Sabin Buragawww.purl.org/net/busaco Exemplificare: utilizarea modulului node-sqlite-purejspentru operatii cu baze de date relationale SQLite nu depinde de alte moduledetalii la http://npmjs.org/package/node-sqlite-purejs
    • var sql = require (node-sqlite-purejs);var nume = [ Tuxy, Pingou, Ux, Ping, Ingu, // nume fictive de pinguini Nes, Xut, Nipu, Guin, Esc ]; Dr. Sabin Buragawww.purl.org/net/busaco// operatii SQL uzuale: creare tabela, inserare date, interogaresql.open (./pinguini.sqlite, {}, function (eroare, bd) { bd.exec (CREATE TABLE tucsi (id integer, nume text, varsta integer)); for (var id = 0; id < 10; id++) { // inseram date (varsta e generata aleatoriu) bd.exec (INSERT INTO tucsi VALUES ( + id + , " + nume[id] + ", + Math.round (Math.random () * 60) + );); }; // preluam pinguinii adulti bd.exec ("SELECT * FROM tucsi WHERE varsta >= 18 ORDER BY nume;", function (eroare, rezultate) { console.log (rezultate); } ); });
    • node.js: module – studiu de caz Dr. Sabin Buragawww.purl.org/net/busacoDorim sa realizam un mini-robot care proceseazacontinutul diverselor resurse disponibile pe Web rol de client pentru un server Web prelucreaza codul HTMLWeb scrapping (metode consacrate: DOM sau SAX)
    • var http = require (http);var qs = require (querystring);var xpath = require (xpath);var dom = require (xmldom).DOMParser; Dr. Sabin Buragawww.purl.org/net/busaco// de exemplu, dorim sa obtinem reprezentarea corespunzatoare resursei// de la http://www.php.net/manual-lookup.php?pattern=cookie&scope=quickrefvar param = { // stabilim parametrii cererii HTTP host: www.php.net, port: 80, method: GET, path: /manual-lookup.php + ? + qs.stringify ({ pattern: cookie, scope: quickref })};var cerere = http.get (param, function (raspuns) { var rezultat = ; // raspunsul poate sosi in fragmente de date raspuns.on (data, function (date) { // tratam evenimentul privitor la aparitia datelor rezultat += date; }); raspuns.on (end, function() { // tratam evenimentul de finalizare a transferului console.log (procesareHTML (rezultat)); });}); conectare la un server Web
    • // realizeaza procesarea dorita (Web scrapping)function procesareHTML (document) { Dr. Sabin Buragawww.purl.org/net/busaco var adrese = []; // instantiem un procesor DOM var doc = new dom().parseFromString (document); // selectam via o expresie XPath elementele <a> incluse in <li> var noduri = xpath.select ("//li/a", doc); // obtinem valoarea atributului href (URL-ul) for (var i = 0; i < noduri.length; i++) { adrese.push (noduri[i].getAttribute (href)); // plasam in tablou } return (adrese);} procesare document cu DOM si XPath
    • node.js: framework-uri web Dr. Sabin Buragawww.purl.org/net/busacoUzual, incurajeaza dezvoltarea de aplicatii Web in care interactiunea cu utilizatorul se realizeaza intr-o singura pagina realtime single-page Web apps
    • node.js: framework-uri web Dr. Sabin Buragawww.purl.org/net/busaco Alte facilitati notabile: MVC (Model-View-Controller)transfer de date in timp-real – e.g., via Socket.IO servicii Web – paradigma REST suport pentru baze de date NoSQL template-uri de prezentare a continutului
    • node.js: framework-uri web – exemple Dr. Sabin Buragawww.purl.org/net/busaco Derby Express Flatiron Geddy Locomotive Meteor Mojito SocketStream TowerJS comparatii (Tyler Renelle, august 2012): http://ocdevel.com/blog/nodejs-frameworks-comparison
    • node.js: utilizari pragmatice Dr. Sabin Buragawww.purl.org/net/busacoDeservire a unui volum mare de conexiuni concurente cu necesar minim de resurse (procesor, memorie) intr-un singur procesProcesare in timp-real a datelor JSON oferite de API-uriDezvoltare rapida de servicii Web sau API-uri conform paradigmei REST (REpresentational State Transfer) Aplicatii oferind fluxuri de date (streaming data)
    • de studiat Dr. Sabin Buragawww.purl.org/net/busaco Situl Node.js oficial – http://nodejs.org/ M. Takada, Mixu’s Node Book – http://book.mixu.net/ Comunitatea Node.js – http://docs.nodejitsu.com/Resurse Node.js – http://github.com/joyent/node/wiki/Resources Ontwik Node.js Videos – http://ontwik.com/category/nodejs/
    • de studiat Dr. Sabin Buragawww.purl.org/net/busacoM. Kiessling, Node Beginner Book – www.nodebeginner.org D. Howard, Node.js for PHP Developers, O’Reilly, 2012P. Teixeira, Professional Node.js: Building JavaScript-based Scalable Software, John Wiley & Sons, 2013 M. Amundsen, Building Hypermedia APIs with HTML5 and Node, O’Reilly, 2012 How To Node – http://howtonode.org/
    • rezumat Dr. Sabin Buragawww.purl.org/net/busacoaplicatii Web la nivel de server cu node.js
    • ?Dr. Sabin Buragawww.purl.org/net/busaco