EML格式是微软公司在Outlook中所使用的一种遵循RFC822及其后续扩展的文件格式,并成为各类电子邮件软件的通用格式。
做个笔记,C# 邮件处理保存为eml格式;
一、网上好多这样的写法,可以在.net formwork4.5里面 百试不爽…………
/// <summary>
/// 2.0可以允许 4.5不可以
/// </summary>
/// <param name="msg"></param>
/// <returns></returns>
public static byte[] MailMessageToArray(MailMessage msg)
{
const BindingFlags flags = BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.FlattenHierarchy;
using (var ms = new MemoryStream())
{
var assembly = typeof(SmtpClient).Assembly;
var writerType = assembly.GetType("System.Net.Mail.MailWriter");
var writer = Activator.CreateInstance(writerType, flags, null, new object[] { ms }, CultureInfo.InvariantCulture);
msg.GetType().GetMethod("Send", flags).Invoke(msg, new[] { writer, true });
return ms.ToArray();
}
}
.netformwork 4.5 运行报错---“用户代码未处理TargetParameterCountException 参数不匹配”
二、柳暗花明
不得不说还是老外的技术牛逼些……
/// <summary>
/// MailMessage 转换成eml
/// </summary>
/// <param name="msg">MailMessage</param>
/// <returns>eml字符串</returns>
static string MailMessageToEml(MailMessage msg)
{
Assembly assembly = typeof(SmtpClient).Assembly;
Type mailWriterType = assembly.GetType("System.Net.Mail.MailWriter");
using (MemoryStream stream = new MemoryStream())
{
ConstructorInfo mailWriterContructor = mailWriterType.GetConstructor(BindingFlags.Instance | BindingFlags.NonPublic, null, new[] { typeof(Stream) }, null);
object mailWriter = mailWriterContructor.Invoke(new object[] { stream });
MethodInfo sendMethod = typeof(MailMessage).GetMethod("Send", BindingFlags.Instance | BindingFlags.NonPublic);
sendMethod.Invoke(msg, BindingFlags.Instance | BindingFlags.NonPublic, null, new[] { mailWriter, true, true }, null);
return System.Text.Encoding.UTF8.GetString(stream.ToArray());
//return Encoding.Default.GetString( stream.ToArray());
}
}
效果杠杆的
国外的大牛就是一样,发现和他的差距太TM的不小。。。。还有一种解决方案
public static class MailMessageExtensions
{
public static string RawMessage(this MailMessage m)
{
var smtpClient = new SmtpClient { DeliveryMethod = SmtpDeliveryMethod.SpecifiedPickupDirectory }; using (var tempDir = new TemporaryDirectory())
{
smtpClient.PickupDirectoryLocation = tempDir.DirectoryPath;
smtpClient.Send(m);
var emlFile = Directory.GetFiles(smtpClient.PickupDirectoryLocation).FirstOrDefault();
if (emlFile != null)
{
return File.ReadAllText(emlFile);
}
else
return null;
}
return null;
} } class TemporaryDirectory : IDisposable
{
public TemporaryDirectory()
{
DirectoryPath = Path.Combine(Path.GetTempPath(), Path.GetRandomFileName());
Directory.CreateDirectory(DirectoryPath);
} public string DirectoryPath { get; private set; } public void Dispose()
{
if (Directory.Exists(DirectoryPath))
Directory.Delete(DirectoryPath, true);
}
}
调用方法
public void Mime(string mailFrom, string subject, string body, string mailTo)
{
MailMessage message = new MailMessage();
message.From = new MailAddress(mailFrom, "", Encoding.UTF8);
message.To.Add(new MailAddress(mailTo));
message.Subject = subject;
message.SubjectEncoding = Encoding.UTF8;////主题编码
message.Body = body;// "<html><body><h1>Welcome</h1><br>This is an HTML message for outofmemory.cn.</body></html>";
message.IsBodyHtml = true;
message.BodyEncoding = Encoding.UTF8;//邮件内容编码
message.Priority = MailPriority.High;//优先级 //string str=MailMessageToEml(message);
string ems = MailMessageExtensions.RawMessage(message);
}
结果然是令人兴奋,对比而言选择方案一,至于为什么……看看代码就晓得了!