我正在尝试将HTML代码导出为PDF。我需要保存到客户端浏览器而不是服务器。我在网上所能找到的就是保存到root,然后下载到浏览器。如果可能的话,我想避开那一步。
void ExportPDF()
{
SelectPdf.HtmlToPdf converter = new SelectPdf.HtmlToPdf();
SelectPdf.PdfDocument doc = converter.ConvertUrl("https://selectpdf.com");
doc.Save("test.pdf");
doc.Close();
}
查看可以保存到Stream
的文档。所以你的代码应该是
SelectPdf.HtmlToPdf converter = new SelectPdf.HtmlToPdf();
SelectPdf.PdfDocument doc = converter.ConvertUrl("https://selectpdf.com");
using (var ms = new System.IO.MemoryStream())
{
doc.Save(ms);
doc.Close();
// todo- create response using the data in `ms`
}
由于这是一个Blazor问题,我想问这个方法是否在组件内部?如果是这样的话,就没有办法在组件内部的浏览器上下载文件。您需要在控制器操作中编写此方法,并返回一个FileResult
。在Blazor组件中,您需要导航到控制器,这将导致浏览器下载文件。
请参阅有没有办法在Blazor中获得下载到浏览器的文件流?了解更多详细信息