O melhor tutorial Rubi envio de correio - SMTP em 2024. Neste tutorial você pode aprender Enviar e-mail HTML com Ruby,Enviar e-mails com anexos,
SMTP (Simple Mail Transfer Protocol) que é Simple Mail Transfer Protocol, que é um conjunto de regras para a transmissão de mensagens de origem para o destino, o que ele tem de controlar a forma como as letras do trânsito.
Rubi oferece uma Net :: SMTP para enviar correio, e fornece dois métodos e novo começo:
novo método tem dois parâmetros:
métodostart tem os seguintes parâmetros:
SMTP método de objeto instanciação chama sendmail, os seguintes parâmetros:
A seguir fornece um script Ruby simples de enviar e-mails:
require 'net/smtp' message = <<MESSAGE_END From: Private Person <me@fromdomain.com> To: A Test User <test@todomain.com> Subject: SMTP e-mail test This is a test e-mail message. MESSAGE_END Net::SMTP.start('localhost') do |smtp| smtp.send_message message, 'me@fromdomain.com', 'test@todomain.com' endNo exemplo acima, você configurou uma mensagem de e-mail básico, prestar atenção ao formato do título correto. Um e-mail para ser De, Para e Assunto, entre texto e informações de cabeçalho requer uma linha em branco.
Use Net :: SMTP para se conectar ao servidor SMTP na máquina local para enviar mensagens usando o processo send_message, parâmetros do processo para o remetente da mensagem com o email do destinatário.
Se você não estiver em execução no servidor SMTP da máquina, você pode usar a comunicação Net :: SMTP com o servidor SMTP remoto. Se você usar serviços de webmail (como Hotmail ou Yahoo Mail), o seu provedor de e-mail irá fornecer detalhes do servidor de envio de email para você:
Net::SMTP.start('mail.your-domain.com')
O código acima irá se conectar acolhimento mail.your-domain.com, número da porta 25 do servidor de correio, se você precisa preencher o nome de usuário e senha, o código é a seguinte:
Net::SMTP.start('mail.your-domain.com', 25, 'localhost', 'username', 'password', :plain)
Os exemplos acima usam um nome de usuário e senha para se conectar ao host especificado mail.your-domain.com, número da porta 25 do servidor de correio.
Net :: SMTP também fornece suporte para o envio de mensagens em formato HTML.
Ao enviar e-mail que você pode definir a versão MIME, tipo de documento conjunto de caracteres para enviar mensagens no formato HTML.
Os exemplos que se seguem são usadas para enviar mensagens em formato HTML:
require 'net/smtp' message = <<MESSAGE_END From: Private Person <me@fromdomain.com> To: A Test User <test@todomain.com> MIME-Version: 1.0 Content-type: text/html Subject: SMTP e-mail test This is an e-mail message to be sent in HTML format <b>This is HTML message.</b> <h1>This is headline.</h1> MESSAGE_END Net::SMTP.start('localhost') do |smtp| smtp.send_message message, 'me@fromdomain.com', 'test@todomain.com' end
Se você precisa enviar um conteúdo misto de e-mail, você precisa definir o tipo de conteúdo é multipart / mista. Assim, você pode adicionar um anexo no conteúdo da mensagem.
Acessório antes da transferência requer o pacote de utilização ( "m") converte o seu conteúdo para o formato base64.
O exemplo a seguir irá enviar anexos como /tmp/test.txt e-mail:
require 'net/smtp' filename = "/tmp/test.txt" # 读取文件并编码为base64格式 filecontent = File.read(filename) encodedcontent = [filecontent].pack("m") # base64 marker = "AUNIQUEMARKER" body =<<EOF This is a test email to send an attachement. EOF # 定义主要的头部信息 part1 =<<EOF From: Private Person <me@fromdomain.net> To: A Test User <test@todmain.com> Subject: Sending Attachement MIME-Version: 1.0 Content-Type: multipart/mixed; boundary=#{marker} --#{marker} EOF # 定义消息动作 part2 =<<EOF Content-Type: text/plain Content-Transfer-Encoding:8bit #{body} --#{marker} EOF # 定义附件部分 part3 =<<EOF Content-Type: multipart/mixed; name=\"#{filename}\" Content-Transfer-Encoding:base64 Content-Disposition: attachment; filename="#{filename}" #{encodedcontent} --#{marker}-- EOF mailtext = part1 + part2 + part3 # 发送邮件 begin Net::SMTP.start('localhost') do |smtp| smtp.sendmail(mailtext, 'me@fromdomain.net', ['test@todmain.com']) end rescue Exception => e print "Exception occured: " + e end
Nota: Você pode especificar o endereço de uma pluralidade de transmissão, mas requer o uso de vírgulas.