Nội dung chính
Web Server là gì?
Web Server là một ứng dụng phần mềm chạy trên máy chủ có thể xử lý các HTTP request được gửi bởi HTTP Client (trình duyệt web) và trả về một trang web. Web Server thường gửi các tài liệu html bên cạnh đó cũng có các file ảnh, CSS và Javascript.
Node.js cung cấp http Module có thể được sử dụng để tạo các HTTP client và server.
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:
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.
Sử dụng Node.js tạo Web Server
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.html 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
Kết quả, truy cập trang: http://127.0.0.1:8081/index.html
Server:
Sử dụng Node.js tạo Web Client
Để 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.html' };// 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ả:
Client:
Kết quả trên Server.