在Blazor Server应用中,由于SignalR的限制,从流下载可能会失败。解决此问题的方法是使用ASP.NET Core Endpoint Routing中的自定义处理程序。以下是如何实现的示例代码:
public class StreamDownloadHandler : IHttpHandler { private readonly Stream _streamToDownload;
public StreamDownloadHandler(Stream streamToDownload)
{
_streamToDownload = streamToDownload;
}
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "application/octet-stream";
context.Response.Headers.Add("Content-Disposition", "attachment;filename=\"file.bin\"");
context.Response.ContentLength = _streamToDownload.Length;
_streamToDownload.CopyTo(context.Response.Body);
}
public bool IsReusable => false;
}
app.UseRouting();
app.UseEndpoints(endpoints => { endpoints.MapGet("/download", async context => { StreamDownloadHandler handler = new StreamDownloadHandler(new MemoryStream(Encoding.UTF8.GetBytes("Hello World!"))); handler.ProcessRequest(context); }); });
此示例为直接从内存中写入流,并将其作为下载的示例,可以根据实际需求更改。
在Blazor组件中,使用HttpClient调用自定义路由处理程序,进行文件的下载。示例代码如下:
@inject HttpClient httpClient
@code { private async Task DownloadFile() { var response = await httpClient.GetAsync("/download");
var stream = await response.Content.ReadAsStreamAsync();
var buffer = new byte[4096];
var fileName = response.Content.Headers.ContentDisposition.FileName;
using (var fileStream = new FileStream(fileName, FileMode.CreateNew))
{
int bytesRead;
do
{
bytesRead = stream.Read(buffer, 0, buffer.Length);
fileStream.Write(buffer, 0, bytesRead);
} while (bytesRead != 0);
}
}
}
这是一个简单的示例,可以根据实
上一篇:BlazorServer中从AzureBlob下载大文件(11MB)出错
下一篇:BlazorServer中的CascadingAuthenticationState与GetAuthenticationStateAsync()返回值不一致