目标:在电子邮件标题中使用唯一的电子邮件地址到:MIME Html 消息的字段(请参阅 message_class)。
文件:database.rb在这里我连接到数据库并循环遍历 table 中的行rcpt
。然后我将值存储在row["email"]
.
require 'mysql2'
class Db
def con
@db_host = "localhost"
@db_user = "root"
@db_pass = "password"
@db_name = "table_db"
client = Mysql2::Client.new(:host => @db_host, :unsername => @db_user, :password => @db_pass, :database => @db_name)
rcpt = client.query("SELECT * from rcpt")
rcpt.each do |row|
row["email"]
end
end
end
con
没有 ["email"]的方法输出:
{"id"=>01, "email"=>"example1@example.com"}
{"id"=>02, "email"=>"example2@example.com"}
con
["email"] 方法的输出:
example1@example.com
example2@example.com
数据库架构:
mysql> describe rcpt;
+-------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+--------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| email | varchar(150) | NO | UNI | NULL | |
+-------+--------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)
文件:message_class.rb在这里我创建了方法pull_rcpt
,然后存储row["email"]
. 然后我尝试使用heredoc中的pull_rcpt
方法。message
现在我的问题来了:在To:
现场,我试图传递我当前发送到的用户电子邮件地址,所以它应该随着接收电子邮件地址而改变。它仍然使用数组/Db 中第一个联系人的电子邮件地址。我究竟做错了什么?
require 'dkim'
require './database'
class Email
def pull_rcpt
rcpt = Db.new
rcpt.con
end
def data
Dkim::domain = 'example.com'
Dkim::selector = 'mail'
Dkim::private_key = open('/path/to/keys/example.com/mail.private').read
message = <<~MESSAGE
From: Eva <test@example.com>
To: Dani <#{pull_rcpt[0]["email"]}>
MIME-Version: 1.0
Content-Type: text/html
Content-Transfer-Encoding: 8bit
Subject: Test Subject
This is an email message.
<h1>Test</h1>
MESSAGE
end
end
文件:mailer_class.rb在我的 mailer_class 中,我有两个方法rcpt_to
和message
. Rcpt_to 包含一个数组contacts
,其中包含 的值row["email"]
。消息构建电子邮件。
require './database'
require './message_class'
def rcpt_to
#conn zu DB & take rcpt
contacts = []
contacts = Db.new
contacts.con
end
def message
#message
message = Email.new
end
几行之后,for loop
我使用如下方法:
for rcpt in rcpt_to do
@protocol = { ehlo: "ehlo", mail_from: "eva@example.com", rcpt_to: [rcpt["email"]], data: Dkim.sign(message.data) }
end
这是 example2@example.com 的标题,它是数据库中的第二条记录:
From: Eva <test@example.com>
To: Dani <example1@example.com> <--- This should be example2(value in hash of second entry in database) not example1
MIME-Version: 1.0
Content-Type: text/html
Content-Transfer-Encoding: 8bit
Subject: Test Subject
Content-Length: 40
所以唯一不起作用的是电子邮件标题中的动态 To: 字段。其余的工作正常,数据库中的所有记录都会收到一封电子邮件。