Я правильно установил 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();
}