首頁  >  文章  >  php框架  >  圖文講解think-queue的使用之用戶註冊場景非同步發送郵件

圖文講解think-queue的使用之用戶註冊場景非同步發送郵件

藏色散人
藏色散人轉載
2021-08-30 17:11:222315瀏覽

本文由thinkphp框架教學專欄為大家介紹think-queue的使用之用戶註冊場景非同步傳送郵件,希望對需要的朋友有幫助!

#本機環境:

##系統是:Mac Os

php版本:7.1
ThinkPHP版本:5.1.15

最近看到think-queue這個擴充類別但是手冊沒寫,很是頭痛,找了很多資料最後寫了個場景,寫的不好大家見諒

首先我們創建專案下載tp框架以及think-queue擴展

創建專案:


圖文講解think-queue的使用之用戶註冊場景非同步發送郵件進入專案目錄查看:

圖文講解think-queue的使用之用戶註冊場景非同步發送郵件

下載擴充類別


圖文講解think-queue的使用之用戶註冊場景非同步發送郵件

下載完畢進入檢視一下:


圖文講解think-queue的使用之用戶註冊場景非同步發送郵件

之後使用MAMP建立虛擬機器


圖文講解think-queue的使用之用戶註冊場景非同步發送郵件

之後建立資料庫以及資料表;

create database if not exists myproject;
use myproject;
DROP TABLE IF EXISTS member;
CREATE TABLE IF NOT EXISTS member(
  id int(11) AUTO_INCREMENT primary key comment 'ID',
  email VARCHAR(32) NOT NULL DEFAULT '' COMMENT '',
  password VARCHAR(255) NOT NULL default '' comment '',
  create_time INT(11) UNSIGNED NOT NULL DEFAULT 0 comment '',
  update_time INT(11) UNSIGNED NOT NULL DEFAULT 0 comment '',
  unique key (email)
)engine innodb charset utf8;
啟動redis 服務


圖文講解think-queue的使用之用戶註冊場景非同步發送郵件

之後一些列的操作,例如開啟強制路由,配置資料庫,配置路由,配置模板標籤等....

建立頁面Register.php控制器目錄:application/index/controller/Register.php

建立Member.php 模型目錄:application/index/model/Member.php
建立Register.php 驗證器目錄:application/index/validate/Register.php
建立處理佇列的檔案sendActivationMail.php 目錄:application/index/job/sendActivationMail .php

在Register控制器裡面建立操作方法

<?php /**
 * User: 李昊天
 * Date: 18/6/7
 * Time: 上午3:15
 * Email: haotian0607@gmail.com
 */

namespace app\index\controller;

use think\Controller;
use app\index\model\Member as MemberModel;
use app\index\validate\Register as RegisterValidate;
use think\Queue;

class Register extends Controller
{
    private $model = &#39;&#39;;

    public function initialize()
    {
        $this->model = new MemberModel();
    }

    /**
     * 渲染模板 展示注册页面
     * @return mixed
     */
    public function index()
    {
        return $this->fetch('index');
    }

    /**
     * 执行注册逻辑
     */
    public function doRegister()
    {
        if ($this->request->isPost()) {
            #实例化验证器 执行验证 如果验证失败跳转并且提示
            $validate = new RegisterValidate();
            $data = $this->request->post();
            if (false === $validate->check($data)) return $this->error($validate->getError());
            //此处应该加密密码 md5 sha1 hash 都可以
            //写入注册的用户
            $result = $this->model->allowField(['email', 'password'])->save($data);
            if ($result) {
                //注册完毕后获取到邮件账号  然后加入到队列
                $this->sendActivationMail($this->model->email);
                return $this->success('注册成功,请前往邮箱激活您的账号!');
            } else {
                return $this->error('注册失败');
            }
        }
    }

    /**
     * @param string $email 邮箱账号
     */
    private function sendActivationMail($email = '')
    {
        $jobName = 'app\index\job\sendActivationMail';  //负责处理队列任务的类
        $data = ['email' => $email]; //当前任务所需的业务数据
        $jobQueueName = 'sendActivationMail'; //当前任务归属的队列名称,如果为新队列,会自动创建


        $result = Queue::push($jobName, $data, $jobQueueName);

        if ($result) {
            echo date('Y-m-d H:i:s') . '一个新的队列任务';
        } else {
            echo date('Y-m-d H:i:s') . '添加队列出错';
        }

        // php think queue:work --queue sendActivationMail --daemon
    }
}
sendActivationMail.php 程式碼

<?php /**
 * User: 李昊天
 * Date: 18/6/7
 * Time: 上午3:36
 * Email: haotian0607@gmail.com
 */

namespace app\index\job;

use think\queue\Job;
use PHPMailer\Mail;
use think\Exception;

class sendActivationMail
{
    /**
     * fire方法是消息队列默认调用的方法
     * @param Job $job 当前的任务对象
     * @param $data 发布任务时自定义的数据
     */
    public function fire(Job $job, $data)
    {
        //执行发送邮件
        $isJobDone = $this->sendMail($data);

        //如果发送成功  就删除队列
        if ($isJobDone) {
            print ("<warn>任务执行成功,,已经删除!" . "</warn>\n");
            $job->delete();
        } else {
            //如果执行到这里的话 说明队列执行失败  如果失败三次就删除该任务  否则重新执行
            print ("<warn>任务执行失败!" . "</warn>\n");
            if ($job->attempts() > 3) {
                print ("<warn>删除任务!" . "</warn>\n");
                $job->delete();
            } else {

                $job->release(); //重发任务
                print ("<info>重新执行!第" . $job->attempts() . "次重新执行!</info>\n");
            }
        }
    }

    /**
     * 发送邮件
     * @param $data
     * @return bool
     */
    private function sendMail($data)
    {
        $title = '账号激活邮件';
        $msg = '欢迎您注册xxx网站,您的请点击一下连接激活您的账号!....';
        try {
            return Mail::send($title, $msg, $data['email']);
        } catch (Exception $e) {
            return false;
        }
    }
}
寫完之後再控制器切換到目前目錄下執行

php think queue:work --queue sendActivationMail --daemon

圖文講解think-queue的使用之用戶註冊場景非同步發送郵件

程式碼裡面有很詳細的註解,但是這個並不完整,,,沒有錯誤的回呼,

等下次有時間的時候再寫剩下的程式碼!

以上是圖文講解think-queue的使用之用戶註冊場景非同步發送郵件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除