Maison  >  Article  >  cadre php  >  Comment utiliser ThinkPHP6 pour l'abonnement par e-mail et le push ?

Comment utiliser ThinkPHP6 pour l'abonnement par e-mail et le push ?

王林
王林original
2023-06-12 08:27:501458parcourir

Avec le développement rapide d'Internet, le courrier électronique, en tant qu'outil de communication le plus traditionnel et le plus stable, est devenu de plus en plus important dans divers secteurs. En tant que développeurs, comment fournir aux utilisateurs des services d'abonnement et de push par courrier électronique fiables et efficaces est devenu un problème auquel nous devons réfléchir et résoudre. Cet article expliquera comment utiliser le framework ThinkPHP6 pour les abonnements par courrier électronique et les opérations push. J'espère qu'il sera utile à tout le monde.

  1. Préparation

Tout d'abord, nous devons installer PHP, Apache/Nginx et d'autres serveurs Web, ainsi que MySQL et d'autres bases de données sur l'installation locale ou le serveur distant. Dans le même temps, nous devons utiliser le protocole SMTP pour envoyer des e-mails, nous avons donc également besoin d'un compte et d'un mot de passe sur le serveur SMTP.

  1. Installer le framework et les packs d'extension

Avant de procéder à des opérations spécifiques, nous devons utiliser composer pour installer le framework ThinkPHP6 et les packs d'extension. Entrez la commande suivante sur la ligne de commande pour installer.

composer create-project topthink/think tp6 --prefer-dist
wget https://github.com/phpmailer/phpmailer/archive/master.zip
unzip master.zip
cp -r phpmailer-master/ tp6/vendor/phpmailer/phpmailer

Parmi eux, la première commande consiste à installer le framework ThinkPHP6, la deuxième commande consiste à télécharger le package d'extension PHPMailer et la troisième commande consiste à copier le package d'extension PHPMailer dans le répertoire du fournisseur de ThinkPHP6.

  1. Configurer les informations de courrier électronique et d'abonnement

Avant d'exécuter la fonction d'abonnement par courrier électronique, nous devons configurer le compte du serveur SMTP, le mot de passe, ainsi que le nom et l'adresse de l'expéditeur dans le fichier .env afin que le processus peut se dérouler sans problème. Envoyer un courrier. Dans le même temps, nous devons également créer un nouveau tableau d'informations d'abonnement pour stocker les informations d'abonnement de l'utilisateur. Dans le framework ThinkPHP6, nous pouvons utiliser la commande migration pour créer une table d'informations d'abonnement nommée Subscribe_info. .env文件中配置SMTP服务器的账号、密码以及发件人姓名和地址,以便程序顺利发送邮件。同时,我们还需要新建一个订阅信息表,以便存储用户的订阅信息。在ThinkPHP6框架中,我们可以使用migration命令创建一张名为subscribe_info的订阅信息表。

php think migrate:run --seed

在执行完以上命令后,我们需要在subscribe_info表中添加以下字段:

  • id:主键,自增长
  • email:用户的邮箱
  • is_subscribed:是否订阅邮件
  1. 编写订阅页面

当我们完成了配置文件和订阅信息表的创建后,我们需要开始编写订阅页面。在ThinkPHP6框架中,我们可以使用tp6/public目录下的index.phpindex.html进行页面的开发。为了展现方便,这里我们直接在index.html中添加一个简单的表单,用于输入用户的邮箱地址并提交。

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>邮件订阅</title>
</head>
<body>
    <h1>邮件订阅</h1>
    <div>
        <form method="POST" action="{:url('/api/subscribe/submit')}">
            邮箱:<input name="email" type="email" required>
            <button type="submit">提交</button>
        </form>
    </div>
</body>
</html>

当用户提交表单后,我们需要将用户输入的邮箱地址保存到订阅信息表中,以便进行邮件推送。

  1. 编写订阅API

为了将用户输入的邮箱地址保存到订阅信息表中,我们需要编写一个名为Subscribe.php的API。在ThinkPHP6框架中,我们可以使用tp6/application/api目录进行API的开发。以下是一个简单的Subscribe.php文件。

<?php
namespace apppicontroller;

use appcommonmodelSubscribeInfo;
use PHPMailerPHPMailerPHPMailer;
use thinkacadeConfig;
use thinkRequest;

class Subscribe
{
    /**
     * 用户提交订阅信息
     * @param  Request $request [description]
     * @return [type]           [description]
     */
    public function submit(Request $request)
    {
        $email = $request->param('email');
        $subscribeInfo = SubscribeInfo::where('email', $email)->find();

        if (empty($subscribeInfo)) {
            $subscribeInfo = new SubscribeInfo();
            $subscribeInfo->email = $email;
            $subscribeInfo->is_subscribed = true;
            $subscribeInfo->save();
        } else {
            $subscribeInfo->is_subscribed = true;
            $subscribeInfo->save();
        }

        $mail = new PHPMailer(true);
        $mail->SMTPDebug = 1;                   
        $mail->isSMTP();                                            
        $mail->CharSet = 'utf-8';                                              
        $mail->SMTPAuth = true;                                       
        $mail->SMTPSecure = 'ssl';                           
        $mail->Host = Config::get('mail_host');               
        $mail->Port = Config::get('mail_port');                              
        $mail->Username = Config::get('mail_username');  
        $mail->Password = Config::get('mail_password');          
        $mail->setFrom(Config::get('mail_from_email'), Config::get('mail_from_name'));
        $mail->addAddress($email);    
        $mail->Subject = '欢迎订阅本站邮件';
        $mail->Body    = '你好,欢迎订阅本站邮件';
        $mail->send();

        return ['code' => 0, 'message' => '订阅成功'];
    }
}

在以上代码中,我们先从请求中获取到用户输入的邮箱地址,并查找订阅信息表中是否已经有该用户的记录。若没有,则新建一条记录;若已有,则将该记录的is_subscribed字段设置为true。

接下来,我们可以使用PHPMailer扩展包来发送邮件。我们先在config目录下的mail.php文件中添加以下配置信息。

# mail.php
<?php
return [
    'mail_host'       => 'smtp.exmail.qq.com',
    'mail_port'       => '465',
    'mail_username'   => 'xxx@xxx.com',
    'mail_password'   => 'xxxx',
    'mail_from_email' => 'xxx@xxx.com',
    'mail_from_name'  => 'xxx',
];

在以上配置信息中,我们填写了SMTP服务器的地址、端口、账号、密码等信息。在Subscribe.php文件中,我们可以将这些信息读取出来,并使用PHPMailer扩展包发送邮件。成功发送邮件后,我们返回给用户一个订阅成功的消息。

  1. 编写邮件推送脚本

当用户成功订阅邮件后,我们需要编写一个邮件推送脚本,以便能够定时将最新的文章内容推送给订阅用户。在ThinkPHP6框架中,我们可以使用tp6/application/command目录进行命令脚本的开发。以下是一个简单的MailPush.php脚本。

# MailPush.php

namespace appcommand;

use appcommonmodelSubscribeInfo;
use PHPMailerPHPMailerPHPMailer;
use thinkconsoleCommand;
use thinkconsoleInput;
use thinkconsoleOutput;
use thinkacadeConfig;

class MailPush extends Command
{
    /**
     * The configuration.
     *
     * @var array
     */
    private $config;

    /**
     * @inheritdoc
     */
    protected function configure()
    {
        $this->setName('mail')
             ->setDescription('Push article to subscribers');
    }

    /**
     * Execute the console command.
     *
     * @param  Input   $input
     * @param  Output  $output
     * @return void
     */
    public function execute(Input $input, Output $output)
    {
        $subscribeInfos = SubscribeInfo::where('is_subscribed', true)->select();

        if ($subscribeInfos) {
            $mail = new PHPMailer(true);
            $mail->SMTPDebug = 1;                   
            $mail->isSMTP();                                            
            $mail->CharSet = 'utf-8';                                              
            $mail->SMTPAuth = true;                                       
            $mail->SMTPSecure = 'ssl';                           
            $mail->Host = Config::get('mail_host');               
            $mail->Port = Config::get('mail_port');                              
            $mail->Username = Config::get('mail_username');  
            $mail->Password = Config::get('mail_password');          
            $mail->setFrom(Config::get('mail_from_email'), Config::get('mail_from_name'));
            $mail->isHTML(true);                                  
            $mail->Subject = '本站新文章通知';
            $mail->Body    = '亲爱的订阅者,我们有新的文章发布了,快来看看吧!';

            foreach ($subscribeInfos as $subscribeInfo) {
                $mail->addAddress($subscribeInfo->email);    
            }

            $mail->send();
        }
    }
}

在以上代码中,我们先从订阅信息表中获取到已经订阅的用户信息,然后通过PHPMailer扩展包发送邮件。我们还需要在config/app.php中添加命令脚本的路径。

# app.php
<?php
return [
    // ...
    'commands'       => [
        'appcommandMailPush'
    ],
    // ...
];
  1. 配置定时任务

当我们编写好邮件推送脚本后,我们需要配置定时任务,以便定时执行邮件推送脚本。在Linux系统下,我们可以使用crontab

crontab -e

Après avoir exécuté la commande ci-dessus, nous devons ajouter les champs suivants à la table subscribe_info :

    id : clé primaire, incrémentation automatique

    email : email de l'utilisateur 🎜🎜is_subscribe : que ce soit E-mail d'abonnement🎜
    🎜Rédaction de la page d'abonnement🎜🎜🎜Après avoir terminé la création du fichier de configuration et du tableau d'informations d'abonnement, nous devons commencer à écrire la page d'abonnement. Dans le framework ThinkPHP6, nous pouvons utiliser index.php et index.html dans le répertoire tp6/public pour le développement de pages. Pour faciliter la présentation, nous ajoutons ici directement un formulaire simple dans index.html pour saisir l'adresse e-mail de l'utilisateur et la soumettre. 🎜
    0 18 * * * /path/to/php /path/to/tp6/think mail
    🎜Une fois que l'utilisateur a soumis le formulaire, nous devons enregistrer l'adresse e-mail saisie par l'utilisateur dans le tableau des informations d'abonnement pour le push par e-mail. 🎜
      🎜Écrire une API d'abonnement🎜🎜🎜Afin d'enregistrer l'adresse e-mail saisie par l'utilisateur dans le tableau d'informations d'abonnement, nous devons écrire une API nommée Subscribe.php. Dans le framework ThinkPHP6, nous pouvons utiliser le répertoire tp6/application/api pour le développement d'API. Vous trouverez ci-dessous un simple fichier Subscribe.php. 🎜rrreee🎜Dans le code ci-dessus, nous obtenons d'abord l'adresse e-mail saisie par l'utilisateur à partir de la demande, et vérifions s'il existe déjà un enregistrement de l'utilisateur dans le tableau d'informations d'abonnement. Sinon, créez un nouvel enregistrement ; s’il existe déjà, définissez le champ is_subscribe de l’enregistrement sur true. 🎜🎜Ensuite, nous pouvons utiliser le package d'extension PHPMailer pour envoyer des e-mails. Nous ajoutons d'abord les informations de configuration suivantes au fichier mail.php dans le répertoire config. 🎜rrreee🎜Dans les informations de configuration ci-dessus, nous avons renseigné l'adresse, le port, le numéro de compte, le mot de passe et d'autres informations du serveur SMTP. Dans le fichier Subscribe.php, nous pouvons lire ces informations et utiliser le package d'extension PHPMailer pour envoyer des e-mails. Après l'envoi réussi de l'e-mail, nous renvoyons un message d'abonnement réussi à l'utilisateur. 🎜
        🎜Écrire un script push d'e-mail🎜🎜🎜Une fois que l'utilisateur s'est abonné avec succès à l'e-mail, nous devons écrire un script push d'e-mail afin que le contenu du dernier article puisse être transmis régulièrement à l'utilisateur abonné. Dans le framework ThinkPHP6, nous pouvons utiliser le répertoire tp6/application/command pour développer des scripts de commande. Ce qui suit est un simple script MailPush.php. 🎜rrreee🎜Dans le code ci-dessus, nous obtenons d'abord les informations de l'utilisateur abonné à partir du tableau d'informations d'abonnement, puis envoyons l'e-mail via le package d'extension PHPMailer. Nous devons également ajouter le chemin du script de commande dans config/app.php. 🎜rrreee
          🎜Configurer les tâches planifiées🎜🎜🎜Après avoir écrit le script push d'e-mail, nous devons configurer la tâche planifiée afin que le script push d'e-mail puisse être exécuté régulièrement. Sous les systèmes Linux, nous pouvons utiliser la commande crontab pour configurer les tâches planifiées. Entrez la commande suivante sur la ligne de commande pour ouvrir le fichier de configuration des tâches planifiées. 🎜rrreee🎜Dans le fichier de configuration de la tâche planifiée, nous ajoutons le contenu suivant, ce qui signifie que le script push email sera exécuté à 6 heures chaque après-midi. 🎜rrreee🎜Après avoir terminé la configuration ci-dessus, nous pouvons pleinement utiliser le framework ThinkPHP6 pour l'abonnement par e-mail et le push. Une fois que l'utilisateur a saisi son adresse e-mail et soumis une demande d'abonnement, le script push d'e-mail enverra le dernier contenu de l'article à l'utilisateur à l'heure spécifiée de la tâche planifiée. J'espère que cela aide tout le monde. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn