rozważyć ten kodAnaliza kodu narzeka, że nie wyrzucam przedmiotów. Co jest nie tak?
private MailMessage GetMailMessageFromMailItem(Data.SystemX.MailItem mailItem)
{
var msg = new MailMessage();
foreach (var recipient in mailItem.MailRecipients)
{
var recipientX = Membership.GetUser(recipient.UserKey);
if (recipientX == null)
{
continue;
}
msg.To.Add(new MailAddress(recipientX.Email, recipientX.UserName));
}
msg.From = new MailAddress(ConfigurationManager.AppSettings["EmailSender"],
ConfigurationManager.AppSettings["EmailSenderName"]);
msg.Subject = sender.UserName;
if (!string.IsNullOrEmpty(alias)) msg.Subject += "(" + alias + ")";
msg.Subject += " " + mailItem.Subject;
msg.Body = mailItem.Body;
msg.Body += Environment.NewLine + Environment.NewLine + "To reply via Web click link below:" + Environment.NewLine;
msg.Body += ConfigurationManager.AppSettings["MailPagePath"] + "?AID=" + ContextManager.AccountId + "&RUN=" + sender.UserName;
if (mailItem.MailAttachments != null)
{
foreach (var attachment in mailItem.MailAttachments)
{
msg.Attachments.Add(new Attachment(new MemoryStream(attachment.Data), attachment.Name));
}
}
return msg;
}
prostu biorę mój typ bazy danych i konwersji na MailMessage. To jest wysłane w innej funkcji.
Analiza kodu mówi, że nie wyrzucam "msg", co jest poprawne. Ale jeśli zrobię to tutaj - otrzymuję wyjątek, kiedy próbuję go wysłać.
Ponadto, narzeka i nie wyrzucaj MemoryStream tutaj:
msg.Attachments.Add (nowy załącznik (new MemoryStream (attachment.Data) attachment.Name));
Nie mam pojęcia, jak prawidłowo go usunąć. Próbowałem różnych rzeczy, ale był coraz wyjątki podczas wysyłania poczty mówiąc: „Stream zamyka”
Jak ukryć ostrzeżenia? – katit
@katit: Pomiń - nie używam analizy kodu. Jestem pewien, że w Internecie jest mnóstwo instrukcji. –
@Dvvoter: Chcesz się skomentować? –