Nodemailer не работает с Aruba Webmail - PullRequest
0 голосов
/ 11 марта 2020

Я бы подключил nodemailer к веб-почте Aruba. Я пробовал это

var smtpTransport = nodemailer.createTransport({
  host: "smtps.aruba.it",
  logger: true,
  secure: true,  
  port: 465,
  auth: {
    user: "****",
    pass: "****"
  },
  tls: {
    rejectUnauthorized: false,
    minVersion: 'TLSv1'
  }
})

но верните эту ошибку

[2020-03-11 17:15:33] DEBUG Sending mail using SMTP/6.4.4[client:6.4.4]
[2020-03-11 17:15:33] DEBUG [aYJ1bl26Zc] Resolved smtps.aruba.it as 62.149.128.218 [cache miss]
[2020-03-11 17:15:33] ERROR [aYJ1bl26Zc] 140671405623168:error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small:../deps/openssl/openssl/ssl/statem/statem_clnt.c:2150:
[2020-03-11 17:15:33] ERROR [aYJ1bl26Zc] 
[2020-03-11 17:15:33] DEBUG [aYJ1bl26Zc] Closing connection to the server using "destroy"
[2020-03-11 17:15:33] ERROR Send Error: 140671405623168:error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small:../deps/openssl/openssl/ssl/statem/statem_clnt.c:2150:
[2020-03-11 17:15:33] ERROR 
[Error: 140671405623168:error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small:../deps/openssl/openssl/ssl/statem/statem_clnt.c:2150:
] {
  library: 'SSL routines',
  function: 'tls_process_ske_dhe',
  reason: 'dh key too small',
  code: 'ESOCKET',
  command: 'CONN'
}

Я также пытался без minVersion, но он возвращает ту же ошибку, только изменение поля функции в ssl_choose_client_version и причина поле в unsupported protocol.

Как я могу решить эту проблему?

Обновление: Я изменил свой код с этим

var smtpTransport = nodemailer.createTransport({
  host: "smtp.mydomain.it",
  logger: true,
  secure: false,
  port: 587,
  auth: {
    user: "******",
    pass: "******"
  },
  tls: {
    minVersion: 'TLSv1.2',
    rejectUnauthorized: false
  }
})

Теперь, благодаря этому изменению, nodemailer может установить sh соединение, но ошибка не исчезнет. Это журнал

[2020-03-13 17:35:41] DEBUG Sending mail using SMTP/6.4.4[client:6.4.4]
[2020-03-13 17:35:41] DEBUG [neeofoVybVs] Resolved smtp.mydomain.it as 62.149.128.200 [cache miss]
[2020-03-13 17:35:41] INFO  [neeofoVybVs] Connection established to 62.149.128.200:587
[2020-03-13 17:35:41] ERROR [neeofoVybVs] 140658187040640:error:1425F102:SSL routines:ssl_choose_client_version:unsupported protocol:../deps/openssl/openssl/ssl/statem/statem_lib.c:1929:
[2020-03-13 17:35:41] ERROR [neeofoVybVs] 
[2020-03-13 17:35:41] DEBUG [neeofoVybVs] Closing connection to the server using "end"
[2020-03-13 17:35:41] ERROR Send Error: 140658187040640:error:1425F102:SSL routines:ssl_choose_client_version:unsupported protocol:../deps/openssl/openssl/ssl/statem/statem_lib.c:1929:
[2020-03-13 17:35:41] ERROR 
[Error: 140658187040640:error:1425F102:SSL routines:ssl_choose_client_version:unsupported protocol:../deps/openssl/openssl/ssl/statem/statem_lib.c:1929:
] {
  library: 'SSL routines',
  function: 'ssl_choose_client_version',
  reason: 'unsupported protocol',
  code: 'ESOCKET',
  command: 'CONN'
}
[2020-03-13 17:35:41] INFO  [neeofoVybVs] Connection closed
[2020-03-13 17:35:41] INFO  [neeofoVybVs] Connection closed

1 Ответ

1 голос
/ 16 марта 2020

Я решил изменить свой код на это.

var smtpTransport = nodemailer.createTransport({
  host: "smtps.aruba.it",
  logger: true,
  debug:true,
  secure: true,
  port:465,
  auth: {
    user: "*****",
    pass: "*****" 
  },
  tls:{
    minVersion: 'TLSv1',
    ciphers:'HIGH:MEDIUM:!aNULL:!eNULL:@STRENGTH:!DH:!kEDH'
  }
})
...