이 기사에서는 PHP 이메일 통합 문제를 소개합니다. PHP는 오늘날 가장 널리 사용되는 웹 개발 프로그래밍 언어 중 하나입니다. 회사에서는 홍보 이메일이나 직원과의 커뮤니케이션 등 새로운 제품을 알리기 위해 사용자에게 이메일을 보냅니다. 아래에서는 인기 있는 Mailtrap 플랫폼을 PHP에 통합하여 여러 이메일을 보내는 방법에 대해 자세히 소개하겠습니다. 도움이 필요한 친구들에게 도움이 되기를 바랍니다~
PHP는 오늘날 가장 인기 있는 웹 개발 프로그래밍 언어 중 하나입니다. 기업은 프로모션 이메일 등 신제품 소식을 알리거나 직원과 소통하기 위해 사용자에게 이메일을 보냅니다.
이 튜토리얼에서는 인기 있는 Mailtrap 플랫폼을 PHP에 통합하여 여러 이메일을 보내는 방법을 살펴봅니다. [추천학습: PHP 동영상 튜토리얼]
이 튜토리얼을 따라가려면 다음 조건이 필요합니다.
PHP의 기본 개념, 바람직하게는 PHP8.0입니다.
SMTP(Simple Mail Transfer Protocol)의 기본 개념입니다.
메일트랩 계정입니다.
이 튜토리얼이 끝나면 이메일 테스트를 위해 Mailtrap을 PHP 애플리케이션에 통합할 수 있을 것입니다.
다양한 애플리케이션을 개발하려면 많은 요구 사항이 필요합니다. 여기에는 모든 것이 계획대로 작동하는지 확인하기 위해 애플리케이션을 테스트하기 위한 요구 사항이 포함됩니다. Edge as a Service와 같은 이러한 애플리케이션의 주요 요구 사항 중 하나는 이메일 기능을 테스트하는 기능입니다.
Co의 고객은 Edge를 서비스로 활용하는 경우가 많으며 유연한 결제 계획을 가지고 있습니다. 이러한 고객에게 다음 기한을 상기시키려면 이메일을 보내야 합니다.
이메일을 보낼 때 가장 어려운 점은 이메일이 제대로 전달되는지 확실하지 않다는 것입니다. 이메일이 확실히 전달되도록 하려면 개발 및 준비 수준에서 이메일을 테스트하여 프로덕션 환경에서 제대로 작동하는지 확인해야 합니다.
이제 Mailtrap은 애플리케이션 개발 프로세스의 개발 및 준비 단계와 함께 제공됩니다. 이메일이 의도한 수신자에게 전달되었는지 확인하기 위해 이메일을 테스트하는 데 사용됩니다. 다음 섹션에서는 PHP의 이메일 전송 방법, 작동 방식, 직면할 수 있는 문제에 대해 자세히 살펴보겠습니다.
PHP에는 시스템 사용자에게 이메일을 보내는 두 가지 방법이 있습니다.
이러한 방법이 있습니다.
PHP 패키지를 사용하는 방법은 다음 섹션에서 살펴보겠습니다.
내장된 메서드를 사용하세요.
이 섹션에서는 PHP의 mail() 메소드를 사용하여 사용자에게 이메일을 보냅니다. 그런 다음 해당 이메일이 전달되었는지 또는 실패했는지 확인하는 작업을 진행합니다.
mail()의 일반적인 구조는 다음과 같습니다.
// the mail method in PHP for sending emails mail( // recipient email string $to, // the email subject string $subject, // the email body string $message, //any other additional settings array|string $additional_headers = [], string $additional_params = "" ): bool
위 메서드는 아래에 설명된 여러 매개변수를 받습니다.
$to : 이 매개변수는 이메일 수신자를 나타냅니다. 이는 다음과 같이 보일 수 있습니다: . test@section.io
$subject: 이메일 제목을 의미하며, RFC 2047 - MIME(Multi Purpose Internet Mail Extensions)을 준수하는지 확인해야 합니다.
$message: 이메일 본문입니다. 각 줄이 CRLF(rn)로 구분되어 있는지 확인해야 합니다. 줄 수는 70자를 초과할 수 없습니다. 그렇지 않으면 이메일이 전송되지 않습니다.
$additional_headers(선택 사항) - 이메일 헤더에 추가 정보를 추가할 수 있도록 보장하는 배열 매개변수입니다. 여기에는 CC, BCC 등이 포함될 수 있습니다.
이제 PHP mail() 메소드의 기본 기능을 이해했으므로 샘플 이메일을 임의의 이메일로 보내는 방법을 살펴보겠습니다.
<?php // sending to $to = 'no-reply@section.io'; // email subject $subject = "Section's Edge as a service"; // additional headers $headers = array( 'From' => 'test@example.com', 'Reply-To' => 'test2@example.com', 'X-Mailer' => 'PHP/' . phpversion() ); //body template $message = ' <html> <head> <title>Node.js Deployment</title> </head> <body> <p>I have a few requests:</p> <ol> <li>How much is the cost?</li> <li>What is the whole procedure of delpoyment</li> <li>How are my appplications distributed?</li> <li>How flexible is the payment plans?</li> </ol> </body> </html> '; mail($to, $subject, $message, $headers);
위 코드에서는 임의의 이메일로 쿼리 이메일을 보내고 있습니다. HTML 본문을 정의하고 제목과 같은 추가 매개변수를 추가했습니다.
참고: HTML 본문을 사용하여 사용자에게 이메일을 보내려면 아래 이미지와 같이 헤더를 설정해야 한다는 점을 기억하는 것이 중요합니다.
$headers[] = 'MIME-Version: 1.0'; $headers[] = 'Content-type: text/html; charset=iso-8859-1';
그렇지 않으면 이메일 본문이 HTML로 전달됩니다. 전송 프로토콜에서 잘못된 콘텐츠가 발견되면 다른 문제가 발생할 수 있습니다. 이 시점에서 우리는 이 특정 코드가 실행될 때 완벽하게 실행될 것으로 예상한다고 가정합니다.
하지만 이메일이 의도한 수신자에게 전달되도록 어떻게 보장할 수 있나요? 다음 섹션에서는 메일 패키지를 사용하여 동일한 이메일을 보내겠습니다. 이러한 패키지는 메일이 배달되었는지 확인하기 어렵게 만드는 mail() 메서드의 한계를 극복하는 데 도움이 됩니다.
이전 이메일 전송 방법의 주요 단점 중 하나는 기능이 매우 제한적이라는 것입니다. 이는 일반적으로 대량의 메일을 보내야 할 때 직면하는 문제입니다.
이 섹션에서는 이러한 단점을 극복하는 방법을 살펴보고 이후 이메일이 의도한 수신자에게 전달되는지 분석할 것입니다.
다음 패키지에 대해 논의하겠습니다.
PHPMailer
Swift Mailer
Pear Mail
让我们继续,先从PHPMailer :PHPMailer是我们上面列出的所有包中最流行的用PHP发送邮件的包之一。
创建一个PHP文件mail.php ,并添加以下代码片段。
<?php // Import the mailer class use PHPMailer\PHPMailer\PHPMailer; require_once './vendor/autoload.php'; // create a new mailing object $mail = new PHPMailer(); // SMTP configuration $phpmailer = new PHPMailer(); $phpmailer->isSMTP(); $phpmailer->Host = 'smtp.mailtrap.io'; $phpmailer->SMTPAuth = true; $phpmailer->Port = 2525; $phpmailer->Username = 'cb7xx33e1856xxx5b25xx'; $phpmailer->Password = '87f63xx87d73e52xxx4xx'; $mail->setFrom('no-reply@section.io', 'Node.js Deployment'); $mail->addAddress('test@gmail.com', 'Me'); $mail->Subject = 'Thanks for using section.io Edge as a service!'; // Our HTML setup $mail->isHTML(TRUE); $mail->Body = '<html>Hello johndoe, thank you for using our Node.js deployment and distribution platform. Kinldy check the document in the attachment below to review your payments plan.</html>'; $mail->AltBody = 'Success'; // adding mailing attachment for payment plan $mail->addAttachment('//node/paymments.pdf', 'payments.pdf'); // send the thank you messange if(!$mail->send()){ echo 'Your message could not be develired, try again later'; echo 'Error: ' . $mail->ErrorInfo; } else { echo 'Your message has been sent successfully.'; }
在上面的代码中,我们已经安装了PHPMailer包。我们还创建了这个类的一个新实例,$mail 。接下来,我们已经创建了我们的Mailtrap账户,并在这里抓取了凭证。
当你创建一个项目时,确保你将其与PHPMailer 选项集成,如下面的截图所示。
你会注意到,我们的截图省略了用户名和密码。这些是自动生成的,对每个用户都是不同的。
接下来,我们设置了我们的setFrom() 方法来接收发件人的电子邮件和电子邮件标题。然后,我们继续配置收件人的电子邮件地址和电子邮件的主题。
注意:之前,我们曾表示,我们可以将正文添加为HTML,然后适当地设置我们的内容类型。
在上面的邮件正文中,我们将信息定义为HTML,以便我们能够定制邮件,满足我们的要求。然后我们添加替代标签,再最后添加一个附件。然后,我们使用PHPMailer的$mail->send() 方法来发送我们的邮件。我们加入了if 语句来检查我们的邮件是否已经发送。
当我们的邮件未能送达时,我们通过打印一个警告信息来通知用户,否则就打印一个成功信息。让我们继续使用SwiftMailer ,实现同样的功能,如下所示。
在你的服务器上创建一个新的文件swift.php ,并添加以下代码片段。
<?php require_once './vendor/autoload.php'; try { // start by creating SMTP transport $transport = (new Swift_SmtpTransport('smtp.mailtrap.io', 2525)) ->setUsername('xxxxxxxxx') ->setPassword('xxxxxxxxx'); $swift_mailer = new Swift_Mailer($transport); // message creation $swift_message = new Swift_Message(); $swift_message->setSubject('Hooray! You just deployed your first Node'); swift_message->setFrom(['no-reply@section.io' => 'Saas']); $messswift_messageage->addTo('test@gmail.com','Test'); // Adding email attachment $email_attachment = Swift_Attachment::fromPath('./section/payments.pdf'); $swift_message->attach($email_attachment); // Set the plain-text part $swift_message->setBody('Hello John Doe, thank you for using the Section Node deployment service'); // Set the HTML part $swift_message->addPart('We are glad to welcome you on board'); // Send the message $res = swift_mailer->send($message); } catch (Exception $e) { echo $e->getMessage(); }
就像PHPMailer一样,我们首先安装这个包,并使用./vendor/autoload.php 路径导入它。还需要注意的是,根据你的系统设置,这个路径可能与你的应用程序路径不同。
接下来,我们将传输设置为使用我们Mailtrap的Swift_SmtpTransport 。拿起你的凭证,按照上面的代码设置。按照前面的步骤来配置你的应用程序,使其使用Mailtrap包来发送邮件。
现在,我们如何知道我们的邮件已经被送达?这就是我们使用Mailrap的原因。与PHPmail() 方法相比,该软件包允许我们配置我们的应用程序使用mailtrap,这给我们提供了一个平台来测试我们的应用程序,正如下一节所讨论的。
登录你的Mailtrap账户,进入你的收件箱部分,如以下截图所示。
接下来,点击项目名称,展开你所发送的邮件。
注意:为了安全起见,上述截图上的一些功能已被跳过。
在这篇文章中,我们已经广泛地讨论了PHP邮件方法的基本概念。我们已经看到了PHP内置的方法mail() 是如何限制我们发送带有测试功能的邮件的,我们已经用PHP包克服了这个问题。
作者:DebugUsery
链接:https://juejin.cn/post/7167615841398161416
위 내용은 Mailtrap이 PHP 이메일을 통합하는 방법에 대해 이야기해 보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!