Ошибка Gmail при отправке локальной электронной почты через Xampp (необходимо выполнить команду STARTTLS)

Я установил сервер XAMPP и теперь пытаюсь отправить свою локальную электронную почту через сервер gmail. Для этого я последовал эта ссылка и изменил мои php.ini и sendmail.ini следующим образом:

php.ini

[mail function]
; For Win32 only.
; http://php.net/smtp
SMTP = smtp.gmail.com
; http://php.net/smtp-port
smtp_port = 587

; For Win32 only.
; http://php.net/sendmail-from
sendmail_from = [email protected]

; For Unix only.  You may supply arguments as well (default: "sendmail -t -i").
; http://php.net/sendmail-path
sendmail_path = "\"C:\xampp\sendmail\sendmail.exe\" -t"
; Force the addition of the specified parameters to be passed as extra parameters
; to the sendmail binary. These parameters will always replace the value of
; the 5th parameter to mail(), even in safe mode.
;mail.force_extra_parameters =

; Add X-PHP-Originating-Script: that will include uid of the script followed by the filename
mail.add_x_header = Off

; Log all mail() calls including the full path of the script, line #, to address and headers
;mail.log = "C:\xampp\php\logs\php_mail.log"

sendmail.ini

; configuration for fake sendmail

; if this file doesn't exist, sendmail.exe will look for the settings in
; the registry, under HKLM\Software\Sendmail

[sendmail]

; you must change mail.mydomain.com to your smtp server,
; or to IIS's "pickup" directory.  (generally C:\Inetpub\mailroot\Pickup)
; emails delivered via IIS's pickup directory cause sendmail to
; run quicker, but you won't get error messages back to the calling
; application.

smtp_server=smtp.gmail.com

; smtp port (normally 25)

smtp_port=587

; the default domain for this server will be read from the registry
; this will be appended to email addresses when one isn't provided
; if you want to override the value in the registry, uncomment and modify

;default_domain=local

; log smtp errors to error.log (defaults to same directory as sendmail.exe)
; uncomment to enable logging

error_logfile=error.log

; create debug log as debug.log (defaults to same directory as sendmail.exe)
; uncomment to enable debugging

debug_logfile=debug.log

; if your smtp server requires authentication, modify the following two lines

[email protected]
auth_password=xxx

; if your smtp server uses pop3 before smtp authentication, modify the
; following three lines

;pop3_server=
;pop3_username=
;pop3_password=

; to force the sender to always be the following email address, uncomment and
; populate with a valid email address.  this will only affect the "MAIL FROM"; command, it won't modify the "From: " header of the message content

[email protected]

; sendmail will use your hostname and your default_domain in the ehlo/helo
; smtp greeting.  you can manually set the ehlo/helo name if required

;hostname=localhost

С этими настройками я получу следующую ошибку от сервера gmail:

16/01/18 20:47:28 ** Connecting to smtp.gmail.com:587
16/01/18 20:47:28 ** Connected.
16/01/18 20:47:28 << 220 smtp.gmail.com ESMTP w80sm17190895wme.17 - gsmtp<EOL>
16/01/18 20:47:28 >> EHLO SamClauw<EOL>
16/01/18 20:47:28 << 250-smtp.gmail.com at your service, [213.118.20.101]<EOL>250-SIZE 35882577<EOL>250-8BITMIME<EOL>250-STARTTLS<EOL>250-ENHANCEDSTATUSCODES<EOL>250-PIPELINING<EOL>250-CHUNKING<EOL>250 SMTPUTF8<EOL>
16/01/18 20:47:28 ** Authenticating as [email protected]
16/01/18 20:47:28 >> MAIL FROM: <[email protected]><EOL>
16/01/18 20:47:28 << 530 5.7.0 Must issue a STARTTLS command first. w80sm17190895wme.17 - gsmtp<EOL>
16/01/18 20:47:28 ** Disconnecting from smtp.gmail.com:587
16/01/18 20:47:28 ** Disconnected.
16/01/18 20:47:28 ** Disconnected.
16/01/18 20:47:28 ** Must issue a STARTTLS command first. w80sm17190895wme.17 - gsmtp<EOL>

Как видите, я установил соединение, но после этого возникла проблема с командой STARTTLS или чем-то еще.

Я гуглил и много пробовал

  • права администратора для XAMPP
  • smtp порт 25 и 465
  • ssl: //smtp.gmail.com вместо smtp.gmail.com
  • низкий уровень безопасности на моем аккаунте Gmail

Но ничто из этого не помогает. Есть ли кто-то, кто имел такую ​​же проблему и мог это исправить? Какую настройку я должен изменить, чтобы она наконец заработала?

Спасибо 😉

1

Решение

У меня была одна и та же проблема, поэтому я попытался подключиться через TLS, и это сработало.
это мой вывод из моей почтовой программы:

$mail->SMTPSecure = 'tls';
$mail->Host = 'smtp.gmail.com';
$mail->Port = 587;
$mail->SMTPOptions = array(
'ssl' => array(
'verify_peer' => false,
'verify_peer_name' => false,
'allow_self_signed' => true
)
);

Я использую phpmailer (https://github.com/PHPMailer/PHPMailer/), поэтому вы должны попытаться подключиться к хосту: tls: //smtp.gmail.com: 587.

1

Другие решения

задавать smtp_ssl авто в sendmail.ini

; SMTPS (SSL) support
; auto = use SSL for port 465, otherwise try to use TLS
; ssl  = alway use SSL
; tls  = always use TLS
; none = never try to use SSL

smtp_ssl=auto
0

По вопросам рекламы [email protected]