c# - Closedxml:无法下载文件并立即通过邮件发送

标签 c# asp.net email closedxml

我想下载一个 excel 文件并自动将文件发送到一个邮箱地址。下载文件有效,但是当我包含用于发送邮件的代码时,它会抛出一个 FileNotFoundException:'Could not find file 'C:\Users\User\source\repos\Project\Taijitan\Taijitan\O soto gari.xlsx'。 '.

我注意到在下载文件时,它会自动转到我电脑上的“下载”文件夹。当我取消注释邮件代码时,它似乎没有下载,而是在抛出我上面提到的错误之前加载。我尝试使用 Path.GetFullPath(name) 来查找 excel 文件,这样我就不必对任何路径进行硬编码(以防我的同事有不同的路径),但它似乎不起作用。

Controller

 public IActionResult GenerateList(int id)
    {
        Lesson lesson = _lessonRepository.GetBy(id);
        var download = lesson.GetCommentsList();
        string file = lesson.Name + ".xlsx";
        MailSender.SendListMail(lesson.Name, file);
        return download;
    }

生成excel + 下载

    public List<Comment> Comments { get; set; }
    public IActionResult GetCommentsList()
    {
        List<string> list = new List<string>();
        var wb = new XLWorkbook();
        var ws = wb.Worksheets.Add("Comments");
        foreach (var comment in Comments)
        {
            list.Add(comment.Body);
        }

        string name = Name + "comment";
        ws.Cell(1, 1).Value = name;
        ws.Range(1, 1, 1, 1).AddToNamed("Titles");
        var CommentsRange = ws.Cell(2, 1).InsertData(list.AsEnumerable());
        var titlesStyle = wb.Style;
        titlesStyle.Font.Bold = true;
        titlesStyle.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
        titlesStyle.Fill.BackgroundColor = XLColor.Blue;
        titlesStyle.Font.FontColor = XLColor.White;
        wb.NamedRanges.NamedRange("Titles").Ranges.Style = titlesStyle;
        ws.Columns().AdjustToContents();
        wb.SaveAs(name + ".xlsx");

        using (var stream = new MemoryStream())
        {

            wb.SaveAs(stream);
            stream.Flush();
            return new FileContentResult(stream.ToArray(),
                "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")
            {
                FileDownloadName = name + ".xlsx"
            };
        }
    }

邮件发送器

 public static void SendListMail(string list, string file)
    {
        MailAddress Sender = new MailAddress("SenderEmail@gmail.com", "CommentsSender");
        MailAddress Receiver = new MailAddress("ReceiverEmail@gmail.com", "Comments inbox");
        const string SenderPassword = "password123";

        string Attachment = Path.GetFullPath(file);

        SmtpClient smtp = new SmtpClient
        {
            Host = "smtp.gmail.com",
            Port = 587,
            EnableSsl = true,
            DeliveryMethod = SmtpDeliveryMethod.Network,
            UseDefaultCredentials = false,
            Credentials = new NetworkCredential(Sender.Address, SenderPassword),
            Timeout = 30000
        };
        using (MailMessage message = new MailMessage(Sender, Receiver)
        {
            Subject = list,
            Body = "List in attachment",
            Attachments = {new Attachment(Attachment)}

        })
        {
            smtp.Send(message);
        }
    }

我正在尝试找出问题出在哪里以及如何解决这个问题。 我的猜测是它与同步(在下载完成之前不要发送邮件)和 Path.GetFullPath() 不检查解决方案文件夹之外有关。

编辑 刚刚注意到,当我尝试发送不带附件的电子邮件时,它会发送邮件,但不会下载任何内容,并且选项卡中的加载图标一直在旋转。

EDIT 2 解决了第一个问题,下载方法中返回语句的放置导致了循环。 现在我仍然遇到找不到文件错误。

最佳答案

问题原来是一个愚蠢的错误。文件以“名称”的值保存(file.Name +“comment.xlsx”,但下载/电子邮件发件人正在寻找 file.Name +“.xlsx”(名称中没有“comment”)

关于c# - Closedxml:无法下载文件并立即通过邮件发送,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55317419/

相关文章:

c# - 如何使 DataGridVewLinkColumn 与 DataGridView 的其余部分一起排序

c# - 为 WCF 设置 Ninject

c# - 在过滤器属性中使用 Autofac 进行属性/方法注入(inject)

c# - 针对 Windows 文件的服务器端病毒扫描

html - 从 HTML 表单转换为 '+' 的空格

php mail() header 阻止电子邮件发送

php Mail() 和 Outlook

c# - 在 Windows 应用商店应用程序中使用 hmacsha256

c# - 收到的 Web 服务 XML 响应为 "text/plain"。 (又一个内容类型错误。)

asp.net - SignalR 3的开发状况如何?