+5

Gửi mail laravel : sử dụng Sendgrid key - dynamic key - inline image

Hello anh em. Bài này mình xin giới thiệu 1 vài cái hay ho với việc gửi mail trong laravel.
Nội dung có trong bài viết này

  1. Đăng ký tài khoản sendgrid tạo sendgrid key free 30 ngày với 100 email/day
  2. Gửi mail sử dụng sendgrid key
  3. Gửi mail với dynamic key sendgrid
  4. Gửi mail kèm hình ảnh nội tuyến (inline image)
    Bắt đầu thôi !

Đăng ký tài khoản sendgrid tạo sendgrid key

Tạo tài khoản gửi Email

  1. Bạn cần truy cập SendGrid để đăng ký một tài khoản. Bạn cần phải nhập thông tin tài khoản đăng ký và tiếp tục nhập các thông tin khác 1 lần nữa, hãy nhập chính xác vì sendgrid kiểm tra rất kỹ, nếu thông tin không trung thực sẽ không thể đăng ký được.
  2. Khi bạn đăng ký thành công thì sẽ có 1 email xác nhận gửi đến mail bạn vừa đăng ký.

    Confirm email để hoàn tất.

Tạo sendgrid key

Sendgrid API Key là một chuỗi ký tự xác thực thay cho tài khoản gửi mail của bạn. Tại trang Dashboard của Sendgrid bạn chọn mục API keys -> ở góc phải màn hình bạn chọn Create API key. Click vào General API key. Chuỗi key được tạo ra và bạn cần lưu lại nó để sử dụng.

Gửi mail sử dụng sendgrid key

Để demo phần này thì mình tạo project laravel

  1. Tạo project laravel composer create-project --prefer-dist laravel/laravel sendmail
  2. Tạo file .env từ .env.exemple
  3. Tạo controller để sử lý việc gửi mail php artisan make:controller MailController
  4. Thêm route ở file web.php Route::get('/send', 'MailController@sendMail');
  5. Viết function sendMail() ở trong MailController
    Đến bước này thì run server lên và test gọi route xem vào được function sendMail chưa nhé, ok rồi thì mình bắt đầu viết phần send mail
    Send Mail
    Trước hết ta cần cài thư viện https://github.com/sendgrid/sendgrid-php để gửi mail nhé.
    Thư viện này giúp chúng ta gửi mail bằng sendgrid key hỗ trợ inline image và cả sử dụng sendgrid key động nữa => 1 trong 3 rồi, ngon ghê.
  • Đầu tiên bạn cần cài bằng lệnh thông qua Composer.
    sudo composer require sendgrid/sendgrid
    Chạy xong lệnh thì kiểm tra phiên bản sendgrid trong file composer.json. Cài thư viện xong rồi thì chúng ta cần viết code gửi mai ở function sendMail.
      public function sendMail() {
        $emailFrom = "abc@sun-asterisk.com";
        $nameFrom = "Name abc";
        $subject = "Đây là tiêu đề!";

        $emailTo = "nguyenthinhhn98@gmail.com";
        $nameTo = "Nguyễn Thịnh";
        $template = "<h1>hello </h1>";
        $key = "Add your Sendgrid Key here";


        $email = new \SendGrid\Mail\Mail();
        $email->setFrom($emailFrom, $nameFrom);
        $email->setSubject($subject);
        $email->addTo($emailTo, $nameTo);
        $email->addContent('text/html', $template);
        $sendgrid = new \SendGrid($key);
        $response = $sendgrid->send($email);
        return $response;
    }

Giải thích code:

  • $emailFrom, $nameFrom: Đây là tên mà email ngửi sẽ hiển thị ở email gửi đi.
  • $subject : tiêu đề email
  • $emailTo, $nameTo: email và name người nhận
  • $template : nội dung email gửi đi ở đây mình để định dang text/html là có thể gửi đi dạng text và các thẻ html cũng sẽ hiển thị
  • $key : key sendgrid mà mình đã đăng ký ở trên.
    Vậy là gửi được mail rồi.

Gửi mail với dynamic key sendgrid

Về việc gửi mail key động. Chúng ta chỉ việc thay đổi giá trị biến $key, khi đó $email tạo ra sẽ phụ thuộc vào key đó, không giống như các phương pháp gửi mail khác thì chúng ta sẽ phải set lại key trong config.

Gửi mail kèm hình ảnh nội tuyến (inline image)

Thư viện trên https://github.com/sendgrid/sendgrid-php đã tích hợp inline image cho chúng ta sử dung CID Việc inline image sẽ giúp các hình ảnh gửi đi có thể thích hợp với nhiều trình duyệt hơn, linh ảnh sẽ khác ban đầu do sử dụng CID.
1 hình ảnh được gửi đi có link như dưới đây

Cảm ơn mọi người đã theo dõi, phần sau mình sẽ viết thêm về 1 số kỹ thuật nho nhỏ về gửi mail trong laravel nữa, cùng theo dõi nhé.


All rights reserved

Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí