Я использую PHPMailer вместе с Apache и PHP локально. Когда я тестирую свою конфигурацию SSL и свои cacerts, я получаю
default_cert_file = C:\Program Files\Common Files\SSL/cert.pem
default_cert_file_env = SSL_CERT_FILE
default_cert_dir = C:\Program Files\Common Files\SSL/certs
default_cert_dir_env = SSL_CERT_DIR
default_private_dir = C:\Program Files\Common Files\SSL/private
default_default_cert_area = C:\Program Files\Common Files\SSL
ini_cafile =
ini_capath =
а потом я делаю
var_dump(fsockopen("smtp.gmail.com", 465, $errno, $errstr, 3.0));
var_dump($errno);
var_dump($errstr);
и я получаю
fsockopen resource(2) of type (stream) int(0) string(0) ""
В моем php.ini
у меня curl.cainfo = C:/php/cacert.pem
в части curl
и он работает.
Но когда я пытаюсь использовать PHPMailer для отправки почты с localhost, я продолжаю получать
SSL operation failed with code 1. OpenSSL Error messages:error:1416F086:SSL routines:tls_process_server_certificate:certificate verify failed
Failed to enable crypto
unable to connect to ssl://smtp.gmail.com:465 (Unknown error)
Я также зашел в учетную запись, используемую в SMTP, в https://accounts.google.com/DisplayUnlockCaptcha
и включил ее. И https://myaccount.google.com/lesssecureapps?pli=1
и включили менее защищенные приложения. Я предполагаю, что это ошибка SSL, а не PHPMailer. Честно говоря, я сбит с толку, не знаю, как это исправить. Извините за мое незнание, любая помощь о том, что не так и как это исправить, была бы замечательной.
PS, это мой php файл, который отправляет почту. Спасибо
<?php
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception;
require 'C:/php/PHPMailer/src/Exception.php';
require 'C:/php/PHPMailer/src/PHPMailer.php';
require 'C:/php/PHPMailer/src/SMTP.php';
$mail = new PHPMailer(true);
try {
$mail->SMTPDebug = 3;
$mail->isSMTP();
$mail->Host = 'smtp.gmail.com';
$mail->SMTPAuth = true;
$mail->Username = '[email protected]';
$mail->Password = 'secret';
$mail->SMTPSecure = 'ssl';
$mail->Port = 465;
//Recipients
$mail->setFrom('[email protected]');
$mail->addAddress('[email protected]');
//Content
$mail->isHTML(true);
$mail->Subject = 'subject';
$mail->Body = 'HTML message body <b>in bold!</b>';
$mail->AltBody = 'body in plain text';
$mail->send();
echo 'Message has been sent';
} catch (Exception $e) {
echo 'Message could not be sent.';
echo 'Mailer Error: ' . $mail->ErrorInfo;
}
?>
Обновить
Когда я пытаюсь использовать $mail->SMTPSecure = 'ssl';
и $mail->Port = 465;
, я получаю
2017-10-01 13:04:25 Connection: opening to ssl://smtp.gmail.com:465, timeout=300, options=array()
2017-10-01 13:04:26 Connection failed. Error #2: stream_socket_client(): SSL operation failed with code 1. OpenSSL Error messages:error:1416F086:SSL routines:tls_process_server_certificate:certificate verify failed [C:\php\PHPMailer\src\SMTP.php line 324]
2017-10-01 13:04:26 Connection failed. Error #2: stream_socket_client(): Failed to enable crypto [C:\php\PHPMailer\src\SMTP.php line 324]
2017-10-01 13:04:26 Connection failed. Error #2: stream_socket_client(): unable to connect to ssl://smtp.gmail.com:465 (Unknown error) [C:\php\PHPMailer\src\SMTP.php line 324]
2017-10-01 13:04:26 SMTP ERROR: Failed to connect to server: (0)
SMTP connect() failed. https://github.com/PHPMailer/PHPMailer/wiki/Troubleshooting
Message could not be sent.Mailer Error: SMTP connect() failed. https://github.com/PHPMailer/PHPMailer/wiki/Troubleshooting
Когда я пытаюсь использовать $mail->SMTPSecure = 'tls';
и $mail->Port = 587;
, я получаю
2017-10-01 13:07:20 Connection: opening to smtp.gmail.com:587, timeout=300, options=array()
2017-10-01 13:07:21 Connection: opened
2017-10-01 13:07:21 SERVER -> CLIENT: 220 smtp.gmail.com ESMTP l4sm5217189wrb.74 - gsmtp
2017-10-01 13:07:21 CLIENT -> SERVER: EHLO localhost
2017-10-01 13:07:21 SERVER -> CLIENT: 250-smtp.gmail.com at your service, [85.75.196.114]250-SIZE 35882577250-8BITMIME250-STARTTLS250-ENHANCEDSTATUSCODES250-PIPELINING250 SMTPUTF8
2017-10-01 13:07:21 CLIENT -> SERVER: STARTTLS
2017-10-01 13:07:21 SERVER -> CLIENT: 220 2.0.0 Ready to start TLS
2017-10-01 13:07:21 Connection failed. Error #2: stream_socket_enable_crypto(): SSL operation failed with code 1. OpenSSL Error messages:error:1416F086:SSL routines:tls_process_server_certificate:certificate verify failed [C:\php\PHPMailer\src\SMTP.php line 403]
SMTP Error: Could not connect to SMTP host.
2017-10-01 13:07:21 CLIENT -> SERVER: QUIT
2017-10-01 13:07:21 SERVER -> CLIENT:
2017-10-01 13:07:21 SMTP ERROR: QUIT command failed:
2017-10-01 13:07:21 Connection: closed
SMTP Error: Could not connect to SMTP host.
Message could not be sent.Mailer Error: SMTP Error: Could not connect to SMTP host.
SMTPSecure = 'tls'
и порта 587 может показать больше обратной связи в отладочных выводах. - person Synchro   schedule 01.10.2017Error #2: stream_socket_enable_crypto(): SSL operation failed with code 1. OpenSSL Error messages:error:1416F086:SSL routines:tls_process_server_certificate:certificate verify failed
, а затемSMTP Error: Could not connect to SMTP host.
. Я начинающий. Что меня смущает, так это то, что моя конфигурация SSL и сертификаты выглядят нормально, но я все еще получаю ошибки. Может быть, я могу обновить свои сертификаты? Спасибо. - person slevin   schedule 01.10.2017echo (extension_loaded('openssl')?'SSL loaded':'SSL not loaded')."\n";
эхоSSL loaded
. Записьopenssl s_client -starttls smtp -crlf -connect smtp.gmail.com:587
в cmd (windows 10) дает'openssl' is not recognized as an internal or external command, operable program or batch file.
Кстати, я смотрю это руководствоhttps://github.com/PHPMailer/PHPMailer/wiki/Troubleshooting
. - person slevin   schedule 01.10.2017SMTPSecure = 'ssl'
и$mail->Port = 465
. Отправьте около 50 писем по электронной почте. А потом просто снова остановился, показывая вышеупомянутые ошибки. Есть ли у сертификатов openssl ограничение на использование? Или это случайное счастливое происшествие? - person slevin   schedule 02.10.2017