- vừa được xem lúc

Xây dựng server với chức năng gửi MAIL, tạo HTML Email Responsive thông qua một vài framework hỗ trợ.

0 0 181

Người đăng: Đặng Xuân Thắng

Theo Viblo Asia

1. Tìm hiểu về Nodemailer

NodeMailer là một trong những module cần thiết nhất nếu như bạn muốn xây dựng một website hoàn hảo. Chúng ta cần phải đặc biệt quan tâm tới việc bảo mật thông tin trong việc gửi và nhận mail nhưng với module Node-mailer điều này trở thành 1 việc rất đơn giản và dễ dàng như trong chính trong câu slogan của chính module này : Send e-mails from Node.js – easy as cake!

2. Chọn SMTP Provider

SMTP là viết tắt của Simple Mail Transfer Protocol dịch ra có nghĩa là một giao thức truyền tải thư tín đơn giản hóa, là một tiêu chuẩn để truyền tải dữ liệu trên môi trường internet.

Và giao thức này thực hiện nhiệm vụ chính là gửi mail còn việc nhận mail hay truy xuất dữ liệu mail server sẽ có giao thức IMAP hay POP3 đảm nhiệm.

Khi nói đến việc sử dụng SMTP trong ứng dụng, mục đích là sử dụng dịch vụ SMTP của bên thứ ba để xử lý các phần về kỹ thuật cho bạn để bạn có thể chỉ tập trung vào ứng dụng của mình. Có rất nhiều nhà cung cấp SMTP khác nhau, mỗi nhà cung cấp đều có những ưu điểm, nhược điểm và chi phí riêng.

Một vài STMP provider ( Gmail, Hotmail, Office365 ... )

// gmail
const smtp = nodemailer.createTransport({ host: 'smtp.gmail.com', ...
}); // hotmail
const smtp = nodemailer.createTransport({ host: 'smtp.live.com', ...
}); // office 365
const smtp = nodemailer.createTransport({ host: 'smtp.office365.com', ...
});

3. Triển khai ứng dụng

3.1 Tạo nhanh ứng dụng nodeJS express

Để tạo nhanh ứng dụng nodeJS express mình sử dụng thư viện express-generator . Các bạn có thể vào trang chủ để tìm hiểu chi tiết.

Cmd:

$ npm install -g express-generator
express --no-view mailer // Option [--no-view], Directory [mailer]

Câu lệnh trên sẽ tạo 1 folder mailer chứa toàn bộ source code của ta.

Install dependancies npm i

Start npm start

Kết quả:

3.2 Cấu hình SMTP server với nodemailer

Đầu tiên chúng ta cài đặt thư viện nodemailer

npm install nodemailer

Tiếp theo ta định nghĩa biến const smtp và gán nó nodemailer.createTransport(), chức năng của phương thức này là thiết lập kết nối máy khách với nhà cung cấp SMTP.

const nodemailer = require('nodemailer') const smtp = nodemailer.createTransport({ host: 'smtp.someprovider.com', // smtp provider port: 587, // 587 là một cổng tiêu chuẩn và phổ biến trong giao thức SMTP secure: false, auth: { user: 'email', địa chỉ email mà ta dùng để gửi mail pass: 'password', password },
});
  • Gửi mail
    Gửi mail với nodemailer cực kì đơn giản, ta chỉ cần gọi phương thức sendMail() thông qua biến smtp ở trên
[...] smtp.sendMail({ to: '_@.com', from: '_@.com', subject: 'Testing Email Sends', // Tiêu đề email html: '<p>Sending some HTML to test.</p>', // Phần nội dung mail mình sẽ dùng html thay vì thuần văn bản thông thường. Nếu muốn gửi văn bản ta thay html bằng text
});
  • Cấp quyền để app đăng nhập vào mail

3.3 Tạo template mail với EJS

Đầu tiên ta cần cài 1 vài thư viện :

npm i ejs html-to-text juice fs

Kết hợp lại ta được: helpers/sendMail.js

const nodemailer = require("nodemailer");
const fs = require("fs");
const ejs = require("ejs");
const { convert } = require("html-to-text");
const juice = require("juice"); const smtp = nodemailer.createTransport({ host: "smtp.gmail.com", port: 587, secure: false, auth: { user: process.env.EMAIL, pass: process.env.PASSWORD, },
}); const sendMail = ({ template: templateName, templateVars, ...restOfOptions
}) => { const templatePath = `templates/${templateName}.html`; // đường dẫn tới template const options = { from: process.env.EMAIL, ...restOfOptions, }; if (templateName && fs.existsSync(templatePath)) { const template = fs.readFileSync(templatePath, "utf-8"); const html = ejs.render(template, templateVars); // templateVars là các biến được truyền vào template thông qua hàm render // const text = convert(html); const htmlWithStylesInlined = juice(html); options.html = htmlWithStylesInlined; //options.text = text; } // hàm smtp.sendMail() này sẽ trả về cho chúng ta một Promise return smtp.sendMail(options);
}; module.exports = { sendMail: sendMail,
}; 
  • Tạo template: templates/template.html
<html> <head> <title>Reset Password</title> </head> <style> body { color: #000; font-family: "Helvetica Neue", "Helvetica", "Arial", sans-serif; font-size: 16px; line-height: 24px; } </style> <body> <p>Hello,</p> <p>My name is (<%= name %>)</p> </body>
</html>
  • Biến name sẽ đc truyền thông qua const html = ejs.render(template, templateVars);

3.4 Tạo controller để nhận request.

controllers/sendMail.js

const { sendMail } = require("../helpers/sendMail"); module.exports.sendMail = async (req, res) => { const data = req.body; // data nhận từ client try { await sendMail({ template: "template", ...data }); res.send("Send mail successfully !"); } catch (error) { res.status(500).send("Send mail fail !"); }
};

router/index.js

var express = require('express');
const { sendMail } = require('../controllers/sendMail');
var router = express.Router(); router.post('/', sendMail); module.exports = router;

3.5 Kết quả.

Mình sẽ dùng Thunder Client (1 extension của VS code) để gửi request:

Vào mail để kiểm tra thôi nào:

3.6 Một vài giải pháp để tạo HTML Email Responsive.

  • Mjml : Mjml là 1 framework cho phép chúng ta coding email responsive 1 cách dễ dàng. (Các bạn có thể tìm hiểu chi tiết hơn qua bài viết này )

  • Chúng ta sẽ lượn 1 vòng qua trang chủ của nó để kiếm 1 chiếc template thật đẹp nào. image.png

  • Chọn template nào mình cảm thấy ưng ý, nếu không thì ta hoàn toán có thể tự xây dựng riêng cho mình 1 template thông qua những cú pháp của mjml:

image.png image.png

  • Sau đó copy source html đã compile từ mjml bỏ vào thư mục: tempalte/template1.html
  • Kết quả: image.png
  • Heml: Các bạn có thể tìm hiểu kĩ hơn thông qua trang chủ của nó, cũng tương tự như mjml =))

image.png

Kết

  • Vậy là chúng ta đã cùng nhau hoàn thiện về ý tưởng về cách triển khai cho việc gửi nhận email trong nodejs và tạo 1 HTML Email Responsive ưng ý thông qua các framework hỗ trợ.
    Cảm ơn các bạn đã dành thời gian đọc bài viết.
    Xin chào và hẹn gặp lại !

  • Source: https://github.com/dangxuanthangqt/viblo_mailer

Tài liệu tham khảo: https://jasonwatmore.com/post/2020/07/20/nodejs-send-emails-via-smtp-with-nodemailer

Bình luận

Bài viết tương tự

- vừa được xem lúc

How To Set Up a Node.js Application for Production with pm2, nginx

Mở đầu. Bài này mình viết với mục đích để tổng hợp lại kiến thức và bổ sung kĩ thuật liên quan đến server cho bản thân.

0 0 86

- vừa được xem lúc

Deploy Serverless với Express và MongoDB

Trong bài viết này, chúng ta sẽ cùng tìm hiểu quá trình xây dựng một ứng dụng web hướng database. Bài viết phù hợp cho developer nào theo hướng full-stack cho các dự án riêng mà không cần phải lo lắng đến việc cài đặt và bảo trì hạ tầng với nhiều service phức tạp.

0 0 41

- vừa được xem lúc

Tạo Web CURD đơn giản với Nodejs + Mysql + EJS

Mở đầu. Trong bài viết này mình sẽ tạo web CRUD đơn giản bằng Nodejs sử dụng Mysql , Express, Ejs.

0 0 34

- vừa được xem lúc

Blog#17: Làm thế nào để chuyển đổi Callback thành Promise trong Javascript/Node.js? 😊 (Series: Bí kíp Javascript - PHẦN 14)

Mình là TUẤN hiện đang là một Full-stack Developer tại Tokyo . Callback : Về JavaScript thì callback là một hàm được truyền dưới dạng tham số cho một hàm khác.

0 0 30

- vừa được xem lúc

Tất tần tật về mô hình MVC

1. Kiến thức nền tảng. 1.1 Tìm hiểu mô hình MVC là gì.

0 0 71

- vừa được xem lúc

Blog#21: Tất cả những gì bạn cần để hiểu về Nodejs 😊 (Series: Bí kíp Javascript - PHẦN 16)

Mình là TUẤN hiện đang là một Full-stack Developer tại Tokyo . Bạn có thể đã đọc những câu này trước đây…. . Node.

0 0 15