Отправка электронной почты с PHPMailer после регистрации - PullRequest
0 голосов
/ 23 апреля 2020

Я правильно установил PHPMailer , но сейчас я пытаюсь использовать его для отправки электронного письма после того, как пользователь создает учетную запись , и я не могу понять, что я делаю неправильно.

Данные вставляются в базу данных, но электронное письмо не отправляется после этого.

Ps: я создал эту регистрационную форму basi c просто для проверки.

Я вставил свой регистрационный код:

<?php
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception;

require $_SERVER['DOCUMENT_ROOT'] . '/mail/Exception.php';
require $_SERVER['DOCUMENT_ROOT'] . '/mail/PHPMailer.php';
require $_SERVER['DOCUMENT_ROOT'] . '/mail/SMTP.php';

if(isset($_POST['registo'])){

    require 'dbh.inc.php';

$username = $_POST['uid'];
$email = $_POST['email'];
$residencia = $_POST ['res'];
$tel = $_POST['tel'];

        // GETS USER IP
       $ip = $_SERVER['REMOTE_ADDR'];

            // GENERATES PASSWORD
            function genPassword($length = 6) {
                $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
                $count = mb_strlen($chars);

                for ($i = 0, $result = ''; $i < $length; $i++) {
                    $index = rand(0, $count - 1);
                    $result .= mb_substr($chars, $index, 1);
                    $result = strtoupper($result);
                }
                return $result;
            }

$password = genPassword();

// INSERTS THE VALUES ON TABLE

        $stateUser = "Active";
        $sql = "INSERT INTO users_tmp (ipUser, cellUser, placeUser, uidUsers, emailUsers, pwdUsers, dataUser, stateUser) VALUES ( ?, ?, ?, ?, ?, ? , now(), ?)";

        $stmt = mysqli_stmt_init($conn);
        if(!mysqli_stmt_prepare($stmt, $sql)){
            header("Location: ../registo-gratis.php?error=sqlerror");
            exit();

        } else {

            mysqli_stmt_bind_param($stmt, "sssssss",  $ip , $tel, $residencia, $username, $email, $password, $stateUser);
            mysqli_stmt_execute($stmt);

А вот мой email код , который я вставил после регистрационный код:


$mail = new PHPMailer();

// Settings
$mail->IsSMTP();
$mail->CharSet = 'UTF-8';
$mail->Host = "ic-producoes.com"; 
$mail->Port = 465; 
$mail->SMTPSecure = 'ssl'; 
$mail->SMTPAuth = true;
$mail->SMTPDebug  = 0;             
$mail->Username = 'info@ic-producoes.com'; // email
$mail->Password = 'mypassword'; // password
$mail->addAddress($email); 
// Content
$mail->isHTML(true);                                 
$mail->Subject = 'My subject';
$mail->Body    = 'This is the HTML message body <b>in bold!</b>';
$mail->send();

echo"Account created ";
        }}
else{
  header("Location: ../registo-gratis.php?error=sqlerror");
            exit();
}

1 Ответ

0 голосов
/ 23 апреля 2020

Попробуйте поместить var_dump () в строку $ mail-> send () и d ie после, например: var_dump ($ mail-> send ()); die; Возможно, вы получите несколько отчетов о состоянии PHPMailer.

...