通过Xampp发送本地电子邮件时出现Gmail错误(必须发出STARTTLS命令)

时间:2016-01-18 20:14:44

标签: php email xampp gmail sendmail.exe

我安装了XAMPP服务器,现在我正在尝试通过gmail服务器发送本地电子邮件。为此,我按照this link并更改了我的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 = xxx.xxx@gmail.com

; 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

auth_username=xxx.xxx@gmail.com
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

force_sender=xxx.xxx@gmail.com

; 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 xxx.xxx@gmail.com
16/01/18 20:47:28 >> MAIL FROM: <xxx.xxx@gmail.com><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帐户的安全性
  • ...

但这一切都没有帮助。是否有人有同样的问题,可以解决这个问题?我应该改变什么设置才能最终起作用?

谢谢;)

2 个答案:

答案 0 :(得分: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 :(得分:0)

在sendmail.ini中将 smtp_ssl 设置为自动

; 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