Get file to send as attachment from byte array

后端 未结 2 494
囚心锁ツ
囚心锁ツ 2021-01-05 14:13

I have an ASP.NET MVC application that has to send an email to a list of recipients with an attachment detailing a specific \"Project\". I get the details for this from a re

相关标签:
2条回答
  • 2021-01-05 14:55

    to do this you would need to leverage off the SSRS ReportManager API as follows.

    1. First read in the report from the Web Service with SSRS
    2. Read the file into memory rather than saving to the server or client
    3. Send the MemoryStream object straight to the email server.

    Reporting services: Get the PDF of a generated report How to send an email with attachments using SmtpClient.SendAsync?

    string strReportUser = "RSUserName";
    string strReportUserPW = "MySecretPassword";
    string strReportUserDomain = "DomainName";
    
    string sTargetURL = "http://SqlServer/ReportServer?" +
       "/MyReportFolder/Report1&rs:Command=Render&rs:format=PDF&ReportParam=" +
       ParamValue;
    
    HttpWebRequest req =
          (HttpWebRequest)WebRequest.Create( sTargetURL );
    req.PreAuthenticate = true;
    req.Credentials = new System.Net.NetworkCredential(
        strReportUser,
        strReportUserPW,
        strReportUserDomain );
    
    HttpWebResponse HttpWResp = (HttpWebResponse)req.GetResponse();
    
    Stream fStream = HttpWResp.GetResponseStream();
    
    HttpWResp.Close();
    
    
    
    //Now turn around and send this as the response..
    ReadFullyAndSend( fStream );
    

    ReadFullyAnd send method. NB: the SendAsync call so your not waiting for the server to send the email completely before you are brining the user back out of the land of nod.

    public static void ReadFullyAndSend( Stream input )
    {
       using ( MemoryStream ms = new MemoryStream() )
       {
          input.CopyTo( ms );
    
            MailMessage message = new MailMessage("from@foo.com", "too@foo.com");
                Attachment attachment = new Attachment(ms, "my attachment",, "application/vnd.ms-excel");
                message.Attachments.Add(attachment);
                message.Body = "This is an async test.";
    
                SmtpClient smtp = new SmtpClient("localhost");
                smtp.Credentials = new NetworkCredential("foo", "bar");
                smtp.SendAsync(message, null);
       }
    }  
    
    0 讨论(0)
  • 2021-01-05 14:56

    Get the file data in a byte[]

    byte[] binaryFile = //  get your file data from the SSRS ...
    string filename = "SSRS.pdf";
    

    Prepare a list or array of the destination addresses:

    string[] addresses = // get addresses somehow (db/hardcoded/config/...)
    

    sending smtp message through SmtpClient:

    MailMessage mailMessage= new MailMessage();
    
    mailMessage.From = new MailAddress("sender email address goes here");
    
    // Loop all your clients addresses
    foreach (string address in addresses)
    {
        mailMessage.To.Add(address);    
    }
    
    mailMessage.Subject = "your message subject goes here";
    mailMessage.Body = "your message body goes here";
    
    MemoryStream memoryStream = new MemoryStream(binaryFile);
    mailMessage.Attachments.Add( new Attachment( memoryStream, filename , MediaTypeNames.Application.Pdf ));
    
    SmtpClient smtpClient = new SmtpClient();
    smtpClient.Send(mailMessage);
    
    0 讨论(0)
提交回复
热议问题