2014-09-13 5 views
0
var nodemailer = require('nodemailer'); 
var smtpTransport = require('nodemailer-smtp-transport'); 

var transport = nodemailer.createTransport(smtpTransport({ 
    host: 'mail.mydomain.com', 
    port: 587, 
    secure: true, 
    auth: { 
    user: 'hello', 
    pass: 'thepassword' 
    } 
})); 

var mailOptions = { 
    from: 'Tester <[email protected]>', // sender address 
    to: '[email protected]', // list of receivers 
    subject: 'Hello', // Subject line 
    text: 'hey', // plaintext body 
    html: 'hey' // html body 
}; 

transport.sendMail(mailOptions, function (error, info) { 
    if (error) { 
    console.log(error); 
    } else { 
    console.log('Message sent: ' + info.response); 
    } 
}); 

Я пытаюсь подключиться к своему собственному постфиксному серверу для отправки электронной почты через SMTP. Однако, когда я запускаю это, я получаю:Получение ошибки SSL при отправке электронной почты, не удается подключиться к Postfix

[Error: 139969407567744:error:140770FC:SSL routines:SSL23_GET_SERVER_HELLO:unknown protocol:../deps/openssl/openssl/ssl/s23_clnt.c:787: ] 

Я уверен, что мой SMTP порт 587. Я уверен, что у меня включен SSL на моем сервере Postfix. Я подключаюсь через SSL из своего приложения Mail на Mac.

Это мой постфикс конфигурация:

myhostname = mail.mydomain.com 
myorigin = mail.mydomain.com 
mydestination = mail.mydomain.com, mydomain.com, localhost, localhost.localdomain 
relayhost = 
mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128 
mailbox_size_limit = 0 
recipient_delimiter = + 
inet_interfaces = all 

alias_maps = hash:/etc/aliases, regexp:/etc/aliases_regex 
#alias_database = hash:/etc/aliases 

smtpd_tls_CAfile=/etc/postfix/tls/startssl-ca-bundle.pem 
smtpd_tls_cert_file=/etc/postfix/tls/mail.mydomain.crt 
smtpd_tls_key_file=/etc/postfix/tls/mail.mydomain.key 
smtpd_use_tls=yes 


smtpd_tls_session_cache_database = btree:${data_directory}/smtpd_scache 
smtp_tls_session_cache_database = btree:${data_directory}/smtp_scache 
smtpd_tls_security_level=may 
smtpd_tls_protocols = !SSLv2, !SSLv3 

#local_recipient_maps = proxy:unix:passwd.byname $alias_maps 

milter_default_action = accept 
milter_protocol = 2 
smtpd_milters = inet:127.0.0.1:8891 
non_smtpd_milters = inet:127.0.0.1:8891 

virtual_alias_domains =mydomain.com 
virtual_alias_maps = hash:/etc/postfix/virtual 

Я использую StartSSL для моего Postfix разъединить. И на моем сервере Node.js, я вижу это:

StartCom_Certification_Authority_2.pem 
StartCom_Certification_Authority_G2.pem 
StartCom_Certification_Authority.pem 

в /etc/ssl. Итак, я предполагаю, что на моем сервере Node.js уже установлены корневые сертификаты.

Когда я запускаю код Node.js выше, я получаю это на мой mail.log:

Sep 13 04:08:30 d-mail postfix/submission/smtpd[724]: connect from unknown[107.170.206.11] 
Sep 13 04:08:30 d-mail postfix/submission/smtpd[724]: lost connection after UNKNOWN from unknown[107.170.206.11] 
Sep 13 04:08:30 d-mail postfix/submission/smtpd[724]: disconnect from unknown[107.170.206.11] 

Я не знаю, почему я не могу соединиться с моего приложения Node.js, но я могу подключить это прекрасно на моем собственном Macbook.

Нужно ли устанавливать какой-либо сертификат на моем сервере Node.js?

ответ

2

С портом 587 вы напрямую не используете SSL, но начинаете с обычного текста, а затем обновляете до SSL с помощью команды STARTTLS. Это означает, что secure должен быть ложным. См. https://github.com/andris9/nodemailer-smtp-transport.

 Смежные вопросы

  • Нет связанных вопросов^_^