AZCode.vn AZCode

Web Module trong Node.js

Web Server là gì ?

Web Server là một ứng dụng phần mềm có thể xử lý các HTTP request được gửi bởi HTTP Client (ví dụ: trình duyệt web) và trả về một trang web trong phản hồi tới Client. Web Server thường gửi các tài liệu html bên cạnh các ảnh cũng như style sheet và các đoạn Javascript.

Cấu trúc ứng dụng Web

Một ứng dụng web thường được chia thành 4 lớp như sau:

Cấu trúc ứng dụng Web
  • Client - Lớp này bao gồm các trình duyệt web và các ứng dụng có thể tạo ra các HTTP request đến Web Server.

  • Server - Lớp này bao gồm các Web Server có thể can thiệp các request được tạo bởi Client và trả về các phản hồi (response).

  • Business - Lớp này bao gồm ứng dụng trên Server có thể được tận dụng bởi các Web Server để thực hiện các tiến trình xử lý cần thiết. Lớp này tương tác với lớp Data qua các chương trình bên ngoài.

  • Data - Lớp này bao gồm các Database và bất kì các nguồn dữ liệu nào.

Tạo Web Server bởi sử dụng Node.js

Node.js cung cấp http Module có thể được sử dụng để tạo các HTTP client và server. Dưới đây là phần kiến trúc thu nhỏ của HTTP Server được lắng nghe trên cổng 8081.

Đầu tiên, bạn tạo server.js có nội dung như sau:

var http = require('http');
var fs = require('fs');
var url = require('url');


// Tao mot Server
http.createServer( function (request, response) {  
   // Parse request co chua ten file
   var pathname = url.parse(request.url).pathname;
   
   // In thong tin ve ten file ma tu do Request duoc tao.
   console.log("Request cho " + pathname + " da duoc nhan.");
   
   // Doc noi dung tu File da duoc yeu cau boi Request
   fs.readFile(pathname.substr(1), function (err, data) {
      if (err) {
         console.log(err);
         // HTTP Status: 404 : NOT FOUND
         // Content Type: text/plain
         response.writeHead(404, {'Content-Type': 'text/html'});
      }else{	
         // HTTP Status: 200 : OK
         // Content Type: text/plain
         response.writeHead(200, {'Content-Type': 'text/html'});	
         
         // Ghi noi dung cua File toi phan BODY cua Response
         response.write(data.toString());		
      }
      // Gui phan BODY cua Response 
      response.end();
   });   
}).listen(8081);

// In thong bao sau tren console
console.log('Server dang chay tai dia chi: http://127.0.0.1:8081/');

Bây giờ tạo index.htm cùng thư mục với server.js:

<html>
<head>
<title>Vi du Web Module trong Node.js</title>
</head>
<body>
Hello World!
</body>
</html>

Chạy server.js để xem kết quả:

$ node server.js

Kiểm tra kết quả

Server dang chay tai dia chi: http://127.0.0.1:8081/

Tạo Request tới Node.js Server

Mở http://127.0.0.1:8081/index.htm trong bất kỳ trình duyệt nào và xem kết quả.

Ứng dụng Node.js

Kiểm tra kết quả:

Server dang chay tai dia chi: http://127.0.0.1:8081/
Request cho /index.htm da duoc nhan.

Tạo Web Client bởi sử dụng Node.js

Để tạo Web Client, bạn cũng có thể sử dụng http Module. Dưới đây là ví dụ minh họa.

Tạo client.js có nội dung sau:

var http = require('http');

// Tao doi tuong options duoc su dung boi Request 
var options = {
   host: 'localhost',
   port: '8081',
   path: '/index.htm'  
};

// Ham callback duoc su dung de xu ly Response
var callback = function(response){
   // Tiep tuc cap nhat du lieu toi Stream
   var body = '';
   response.on('data', function(data) {
      body += data;
   });
   
   response.on('end', function() {
      // Ket thuc qua trinh nhan du lieu.
      console.log(body);
   });
}
// Tao mot Request toi Server
var req = http.request(options, callback);
req.end();

Chạy client.js trên một màn hình Terminal khác để xem kết quả:

$ node client.js

Kiểm tra kết quả:

<html>
<head>
<title>Vi du Web Module trong Node.js</title>
</head>
<body>
Hello World!
</body>
</html>

Tiếp đó kiểm tra kết quả trên Server.

Server dang chay tai dia chi: http://127.0.0.1:8081/
Request cho /index.htm da duoc nhan.

Các bài học NodeJS phổ biến khác tại AZCode: