Home > PHP Framework > ThinkPHP > body text

Use PHPMailer to send emails in ThinkPHP6

WBOY
Release: 2023-06-20 16:03:10
Original
3059 people have browsed it

ThinkPHP6 is a PHP development framework based on MVC architecture. It provides many convenient functions in daily development, including the function of sending emails. This article will introduce how to use PHPMailer to send emails in ThinkPHP6.

1. Install PHPMailer

PHPMailer is an open source PHP email sending class. We can install it through Composer. Run the following command in the project root directory:

composer require phpmailer/phpmailer
Copy after login

After the installation is complete, we can use PHPMailer in the code.

2. Configure email sending parameters

Before starting to send emails, we need to configure the relevant parameters for email sending, including SMTP server, port, account password, etc. We can create a new mail.php file in the application's config directory to save the parameter configuration for email sending. The code is as follows:

<?php

return [
    'host'       => 'smtp.qq.com',
    'port'       => 465,
    'username'   => '邮箱账号',
    'password'   => '邮箱密码',
    'mail_from'  => '发件人邮箱地址',
    'name_from'  => '发件人名称',
    'mail_reply' => '回复邮件地址',
];
Copy after login

3. Write the email sending function

Now we are ready After configuring the parameters required for email sending, we can start writing the email sending function. In ThinkPHP6, we can send emails by customizing a mail service. First, we need to create a new service directory under the application directory and create a new MailService class in it. The code is as follows:

<?php

namespace appservice;

use PHPMailerPHPMailerPHPMailer;
use thinkacadeConfig;

class MailService
{
    public function sendMail($to, $subject, $content)
    {
        $mail = new PHPMailer();
        $config = Config::get('mail');

        $mail->isSMTP(); // 使用SMTP服务发送邮件
        $mail->SMTPAuth = true; // 启用 SMTP 认证
        $mail->Host = $config['host']; // SMTP 服务器
        $mail->Port = $config['port']; // SMTP服务器的端口号
        $mail->Username = $config['username']; // SMTP账号
        $mail->Password = $config['password']; // SMTP密码

        $mail->From = $config['mail_from']; // 发件人邮箱
        $mail->FromName = $config['name_from']; // 发件人名称
        $mail->isHTML(true); // 邮件正文是否为html编码
        $mail->CharSet = 'utf-8'; // 设置邮件字符集
        $mail->addAddress($to); // 收件人邮箱地址
        $mail->Subject = $subject; // 邮件标题
        $mail->Body = $content; // 邮件内容

        if (!$mail->send()) {
            return $mail->ErrorInfo;
        } else {
            return true;
        }
    }
}
Copy after login

In the above code , we used the SMTP method provided by PHPMailer to send emails. Since configuration information needs to be read when sending emails, we use the Config class to obtain the parameter configuration for email sending in the code.

4. Use the email sending function

After completing the writing of the email sending function, we need to call this function in the controller. The following is a simple sample code:

<?php

namespace appcontroller;

use appserviceMailService;

class Index
{
    public function index()
    {
        $to = '收件人邮箱地址';
        $subject = '邮件标题';
        $content = '邮件内容';

        $mailService = new MailService();
        $result = $mailService->sendMail($to, $subject, $content);
        if($result === true){
            echo '发送成功';
        }else{
            echo '发送失败,错误信息:' . $result;
        }
    }
}
Copy after login

By calling the sendMail method in MailService, we can easily send emails.

5. Summary

This article introduces the specific steps of using PHPMailer to send emails in ThinkPHP6. PHPMailer is a powerful open source email sending class that can help us easily implement the email sending function. When using PHPMailer, we need to correctly configure the email sending parameters and write the email sending function according to actual needs.

The above is the detailed content of Use PHPMailer to send emails in ThinkPHP6. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template