現在、送信メールに IIS SMTP を使用している既存の Windows サーバーに DKIM を追加しようとしています。
これは次のようにして実行できるようです電子メールリレー残念ながら、E-Mailrelay で DKIM を正確に設定する方法についての参考資料は見つかりませんでした。
ドキュメントで見逃したものや、これを行う方法を説明しているサードパーティのチュートリアルがあるのでしょうか?
答え1
ここ: https://sourceforge.net/projects/dkimsigningfilter/files/latest/download 上記の変更されたコードに基づいてコンパイルされたアプリです。インストーラーは、ドメイン、セレクター、およびキー パスを ./config にある config.txt ファイルに保存します。このプログラムは、E-Mailrelay のフィルターとして機能します。
答え2
E-MailRelay のフィルターとして機能する、C# / NET 6 を使用したシンプルなコマンド ライン アプリを実装しました。
using System.IO;
using System.Text;
using MimeKit;
using MimeKit.Cryptography;
namespace E_MailRelay.DKIM.Filter;
/// <summary>
/// Reads an e-mail message, adds a Hardcoded DKIM signature and and writes
the updated message back to disk
/// Note that this requires the installation MailKit to work.
/// </summary>
internal class Program
{
private const string DKIMSelector = "ENTER_YOUR_DKIM_SELECTOR_HERE";
private const string _DKIMDomain = "ENTER_YOUR_DOMAIN_NAME_HERE";
private const string DKIMPrivateKey = "-----BEGIN RSA PRIVATE KEY-----\r\n"
+ @"ENTER_YOUR_PRIVATE_KEY_HERE"
+ "\r\n-----END RSA PRIVATE KEY-----";
private static int Main(string[] args)
{
LoadSignAndRewriteMail(args);
return 102;
}
private static void LoadSignAndRewriteMail(string[] args)
{
var emailMessage = MimeMessage.Load(args[0]);
if (!emailMessage.Headers.Contains(HeaderId.DkimSignature)
&& !emailMessage.Headers.Contains(HeaderId.DomainKeySignature))
{
SignMail(emailMessage);
}
emailMessage.WriteTo(args[0]);
}
private static void SignMail(MimeMessage emailMessage)
{
var pk = DKIMPrivateKey;
MemoryStream stream = new(Encoding.UTF8.GetBytes(pk));
{
stream.Position = 0;
}
var dkimSigner = new DkimSigner(stream, _DKIMDomain, DKIMSelector);
HeaderId[] dkimSignHeaders =
{
HeaderId.To, HeaderId.Cc, HeaderId.Subject, HeaderId.From, HeaderId.Date, HeaderId.MessageId, HeaderId.Body,
HeaderId.Date, HeaderId.MimeVersion, HeaderId.Sender, HeaderId.ReplyTo, HeaderId.ContentTransferEncoding,
HeaderId.ContentId, HeaderId.ContentDescription, HeaderId.ResentDate, HeaderId.ResentFrom,
HeaderId.ResentSender, HeaderId.ResentTo, HeaderId.ResentCc, HeaderId.ResentMessageId, HeaderId.InReplyTo,
HeaderId.References
};
dkimSigner.Sign(FormatOptions.Default, emailMessage, dkimSignHeaders);
}
}