带附件的数字签名电子邮件

时间:2014-09-30 09:45:46

标签: c# .net visual-studio-2010 email email-attachments

我有一个邮件程序脚本,可以发送一个经过数字签名的电子邮件。现在我必须将文件附加到邮件中。我的问题:

  1. 如果没有附件,邮件就可以并进行数字签名。这没关系。
  2. 如果有任何附件,邮件正在丢失且未签名,但它会正确发送文件。为什么会这样?
  3. mailer(to, from, from_name, relay, subject, body, attachment_list);

    private void mailer(string toaddress, string fromaddress, string fromaddress_disp, string relays, string mailsubject, string bodytext, List<string> att)
    {
        string certname = "";
    
        MailAddress from = new MailAddress(fromaddress, fromaddress_disp);
        MailAddress to = new MailAddress(toaddress);
        MailMessage message = new MailMessage(from, to);
    
        //this is the attachment part added
        if (att.Count != 0)
            {
                for (int i = 0; i < att.Count; i++)
                {
                    Attachment attachment = new Attachment(att[i].ToString());
                    message.Attachments.Add(attachment);
                }
            }
        //this is the end of attachment part added
    
        message.Subject = mailsubject;
        message.IsBodyHtml = true;
        string body = "Content-Type: text/html; charset=iso-8859-1 \r\nContent-Transfer-Encoding: 8bit\r\n\r\n" + bodytext;
        byte[] messageData = Encoding.ASCII.GetBytes(body);
        ContentInfo content = new ContentInfo(messageData);
    
        SignedCms Cms = new SignedCms(new ContentInfo(messageData));
        X509Store store = new X509Store(StoreLocation.CurrentUser);
        store.Open(OpenFlags.ReadOnly);
    
        RSACryptoServiceProvider csp = null;
        X509Certificate2Collection certCollection = store.Certificates;
        X509Certificate2 cert = null;
        foreach (X509Certificate2 c in certCollection)
        {
            if ((c.Subject.Contains("myEmailAddress")) && (c.FriendlyName.Contains("CompanyEmailDigSig")))
            {
                cert = c;
                break;
            }
        }
    
        if (cert != null)
        {
                csp = (RSACryptoServiceProvider)cert.PrivateKey;
        }
        else
        {
            throw new Exception("Valid certificate was not found");
        }
    
        CmsSigner Signer = new CmsSigner(SubjectIdentifierType.IssuerAndSerialNumber, cert);
        Cms.ComputeSignature(Signer);
        byte[] SignedBytes = Cms.Encode();
        MemoryStream signedStream = new MemoryStream(SignedBytes);
        AlternateView signedView = new AlternateView(signedStream, "application/pkcs7-mime; smime-type=signed-data; name=sig.p7m");
        message.AlternateViews.Add(signedView);
        SmtpClient client = new SmtpClient(relays);
        store.Close();
    
        try
        {
            client.Send(message);
        }
        catch (Exception ex)
        {
        //exception
        }
    }
    

    问题在于它只签署了正文:

    byte[] messageData = Encoding.ASCII.GetBytes(body);
    ContentInfo content = new ContentInfo(messageData);
    SignedCms Cms = new SignedCms(new ContentInfo(messageData));
    

    如何签署整个邮件?

1 个答案:

答案 0 :(得分:0)

我终于可以用EASendMail来解决这个问题:

http://www.emailarchitect.net/easendmail/dev/csharp.asp

此代码将整个电子邮件信息与任何附件和/或嵌入图像一起签名。它也很容易使用。