在Blazor Server应用程序中,所有的交互都是通过SignalR连接实现的,但通过刷新浏览器页面,将会导致SignalR连接丢失,因此页面需要重新加载。这意味着应用程序经常需要强制用户从其URL重新开始,并重建其SignalR连接。而本解决方法将提供一种仅使用一个URL即可避免此问题的方式。
为了解决这个问题,可以使用Blazor的启动代码,通过JavaScript提供的“pushState”和“replaceState”方法,将浏览器URL更改为当前Blazor组件的URL。这可以在页面重载时恢复应用程序的状态,并使用当前URL启动SignalR连接。
下面是在Blazor Server中实现这个解决方法的代码:
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Components;
using Microsoft.AspNetCore.Components.Server;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Primitives;
using System;
namespace BlazorServerOneUrl.Client
{
public class Program
{
public static void Main(string[] args)
{
CreateHostBuilder(args).Build().Run();
}
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup();
})
.ConfigureServices(services =>
{
services.AddServerSideBlazor();
})
.UseBlazorServer();
}
public static class UseBlazorServerExtensions
{
public static IWebHostBuilder UseBl