Curs Javascript

- Citire sirul de interogare din URL
- Despartirea sirului din interogare de URL


Modulul HTTP permite Node.js-ului sa receptioneze si sa transfere date prin Hyper Text Transfer Protocol (HTTP).
Pentru a include modulul HTTP foloseste metoda require()
const http = require('http');

Crearea unui Web server Node.js

Modulul HTTP poate crea un server HTTP care asculta porturile serverului si da un raspuns inapoi clientului.
Foloseste metoda createServer() pentru a crea un server HTTP:
//include the http module
const http = require('http');

//define constant for port
const port =8080;

//sets the server
const server = http.createServer((req, res)=> {
  res.writeHead(200, {'Content-Type':'text/plain'});
  res.write('Hello to me.');
  res.end();
});

//pass the port to server to listen to
server.listen(port, ()=> {
  console.log('Server running at //localhost:'+ port +'/');
});
Functia transmisa la metoda http.createServer() va fi executata cand cineva incearca sa acceseze calculatorul prin portul 8080.
Metoda res.writeHead() include headerele HTTP in raspuns.
Primul argument din metoda res.writeHead() este codul status, 200 inseamna ca totul este in regula, al doilea argument este un obiect care contine headerele de raspuns.
- Daca vrei sa afiseze continut cu taguri html, foloseste header-ul {'Content-Type':'text/html'}.

Am salvat codul de mai sus intr-un fisier numit "server.js" (in directorul "test/"), apoi am initiat fisierul:.

- Serverul Node.js trebuie sa fie initiat in programul "Command Line Interface" de pe calculatorul tau.
Pentru a deschide interfata command line in windows, apasa butonul Start si scrie "cmd" in casuta search.

In interfata windows command line, am navigat pana la directorul care contine aplicatia Node.js (E:/nodejs/), apoi pentru a initia scriptul "server.js", am scris "node test/server.js" si apas Enter.
In interfata windows command line, node.js va afisa: "Server running at //localhost:8080/".
cmd start Node.js
- Acum calculatorul functioneaza ca un server.

Deschid browserul si scriu in casuta adresa: http://localhost:8080
- Resultat:
browser Node.js
• Pentru a inchide serverul Node.js, apasa Ctrl+C in interfata windows command line sau pur si simplu inchide fereastra cmd.

Citire sirul de interogare din URL

Functia trecuta in http.createServer() are un argument "req" care represinta un obiect cu cererea de la client (obiectul http.IncomingMessage).
Acest obiect are o proprietate numita "url" care contine parte din url care vine dupa numele domeniului.

Pentru a testa, salveaza urmatorul cod intr-un fisier numit "demo_http_url.js" si initiaza fisierul in interfata command line.
const http = require('http');

const server = http.createServer((req, res)=> {
  res.writeHead(200, {'Content-Type':'text/plain'});
  res.write(req.url);
  res.end();
});

server.listen(8080, ()=> {
  console.log('Server running at //localhost:8080/');
});
Odata ce serverul Node.js este pornit, daca accesezi serverul in browser cu doua adrese diferite, ar trebui sa vezi doua rezultate diferite
De exemplu, adresa : //localhost:8080/coursesweb
- Produce acest rezultat:
/coursesweb
Accesand adresa : //localhost:8080/marplo?id=1
- Va produce acest rezultat:
/marplo?id=1

Despartirea sirului de interogare din URL

Poti folosi modulul URL integrat pentru a imparti sirul de interogare in parti care pot fi citite. Astfel, se poate afisa continut diferit in functie de datele din interogarea adresei URL.
Exemplu, imparte sirul de interogare in parti care pot fi citite si afiseaza continutul in functie de date din adresa URL.
//include http and url modules
const http = require('http');
const url = require('url');

//object width data for content
var cnt ={
  id:{1:'one', 2:'two', 3:'three'},
  nm:{'a':'Atom', 'e':'Electron', 'n':'Nothing'}
};

//create the server
const server = http.createServer((req, res)=> {
  res.writeHead(200, {'Content-Type':'text/html'}); //adds header to display html content

  //parse the url, get object with {name:value} from url query
  var q = url.parse(req.url, true).query;

  //get and write content from $cnt according to url data
  var cnt_id = cnt.id[q.id] ? cnt.id[q.id] :'No data for id';
  var cnt_nm = cnt.nm[q.nm] ? cnt.nm[q.nm] :'No data for nm';
  var add_cnt ='id '+ q.id +' = '+ cnt_id +'<br>nm '+ q.nm +' = '+ cnt_nm;

  res.write('<h3>'+ req.url +'</h3>'+ add_cnt);
  res.end();
});

server.listen(8080, ()=> {
  console.log('Server running at //localhost:8080/');
});
Salveaza codul de mai sus intr-un fisier numit "demo_url_query.js" si initiaza fisierul cu node.js in interfata command line.
Acceseaza in browserul tau adresa: //localhost:8080/?id=1&nm=a
Va produce acest rezultat:

/?id=1&nm=a

id 1 = one
nm a = Atom

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Ce tag se foloseste pentru a adauga liste in elemente <ul> si <ol>?
<dt> <dd> <li>
<ul>
 <li>http://coursesweb.net/html/</li>
 <li>http://www.marplo.net/html/</li>
</ul>
Care valoare a proprietatii "display" seteaza elementul ca tip bloc si afiseaza un punct in fata?
block list-item inline-block
.some_class {
  display: list-item;
}
Care instructiune JavaScript transforma un obiect in sir JSON.
JSON.parse() JSON.stringify eval()
var obj = {
 "courses": ["php", "javascript", "ajax"]
};
var jsonstr = JSON.stringify(obj);
alert(jsonstr);    // {"courses":["php","javascript","ajax"]}
Indicati clasa PHP folosita pentru a lucra cu elemente HTML si XML in PHP.
stdClass PDO DOMDocument
$strhtml = '<body><div id="dv1">CoursesWeb.net</div></body>';
$dochtml = new DOMDocument();
$dochtml->loadHTML($strhtml);
$elm = $dochtml->getElementById("dv1");
echo $elm->nodeValue;    // CoursesWeb.net
Indicati forma de Prezent Continuu a verbului "to live" (a trai /a locui)
lived living liveing
I`m living here.
- Traiesc /Locuiesc aici.
Care este forma de Gerunziu (sau Participiu Prezent) a verbului "vivir" (a trai /a locui)?
viviĆ³ vivido viviendo
Estoy viviendo aquĆ­.
- Traiesc /Locuiesc aici.
Node.js - Modul HTTP, Crearea unui server simplu

Last accessed pages

  1. Pronume - Exercitii si teste engleza incepatori (15476)
  2. Animatie elemente HTML cu CSS (3194)
  3. Articolul din limba engleza - The article (69192)
  4. Sufixele ful, less si nees - Test engleza (4704)
  5. Subtantive - Plural (5911)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (955)
  2. Gramatica limbii engleze - Prezentare Generala (622)
  3. Exercitii engleza - English Tests and exercises - Grammar (554)
  4. Prezentul simplu si continuu - Present Tense Simple and Continuous (450)
  5. Coduri pt culori (362)