Module URL Node.js
Le module d'URL intégré
Le module URL divise une adresse Web en parties lisibles.
Pour inclure le module URL, utilisez la require()
méthode :
var url = require('url');
Analysez une adresse avec la url.parse()
méthode et elle renverra un objet URL avec chaque partie de l'adresse en tant que propriétés :
Exemple
Divisez une adresse Web en parties lisibles :
var url = require('url');
var adr = 'http://localhost:8080/default.htm?year=2017&month=february';
var q = url.parse(adr, true);
console.log(q.host); //returns 'localhost:8080'
console.log(q.pathname); //returns '/default.htm'
console.log(q.search); //returns '?year=2017&month=february'
var qdata = q.query; //returns an object: { year: 2017, month: 'february' }
console.log(qdata.month); //returns 'february'
Serveur de fichiers Node.js
Nous savons maintenant comment analyser la chaîne de requête et, dans le chapitre précédent, nous avons appris à faire en sorte que Node.js se comporte comme un serveur de fichiers. Combinons les deux, et servons le dossier demandé par le client.
Créez deux fichiers html et enregistrez-les dans le même dossier que vos fichiers node.js.
été.html
<!DOCTYPE html>
<html>
<body>
<h1>Summer</h1>
<p>I love
the sun!</p>
</body>
</html>
hiver.html
<!DOCTYPE html>
<html>
<body>
<h1>Winter</h1>
<p>I love
the snow!</p>
</body>
</html>
Créez un fichier Node.js qui ouvre le fichier demandé et renvoie le contenu au client. Si quelque chose ne va pas, lancez une erreur 404 :
demo_fileserver.js :
var http = require('http');
var url = require('url');
var fs = require('fs');
http.createServer(function
(req, res) {
var q = url.parse(req.url, true);
var
filename = "." + q.pathname;
fs.readFile(filename,
function(err, data) {
if (err) {
res.writeHead(404, {'Content-Type': 'text/html'});
return res.end("404 Not Found");
}
res.writeHead(200, {'Content-Type': 'text/html'});
res.write(data);
return res.end();
});
}).listen(8080);
Pensez à initier le fichier :
Lancez demo_fileserver.js :
C:\Users\Your Name>node demo_fileserver.js
Si vous avez suivi les mêmes étapes sur votre ordinateur, vous devriez voir deux résultats différents lors de l'ouverture de ces deux adresses :
http://localhost:8080/été.html
Produira ce résultat:
Summer
I love the sun!
http://localhost:8080/hiver.html
Produira ce résultat:
Winter
I love the snow!