11

语境:

我们想要创建一个在客户端使用 Blazor WebAssembly 运行的单页应用程序。在服务器端,该解决方案有一个 ASP.NET MVC,其中包括一些用于我们的 REST API 的 ApiController 类。

我们希望在服务器端使用 ASP.NET API 而不是 Blazor Server,因为我们希望为未知的消费者提供带有 ApiController 类的 REST 接口。

这是我在单个解决方案中的客户端(Blazor WebAssembly)和服务器端(ASP.NET API)项目:

在此处输入图像描述

在此处输入图像描述

第一次尝试通过我们的组件中的 Blazor 的 HttpClient 类请求 API FetchData

@inject HttpClient Http
...
@code {
    private TodoItem[] TodoItems;

    protected override async Task OnInitializedAsync()
    {
        TodoItems = await Http.GetJsonAsync<TodoItem[]>("api/ToDo");
    }
}

在服务器端,API-Controller 看起来像:

namespace ToDoListAPI.Controllers
{
    [Route("api/[controller]")]
    [ApiController]
    [Produces("application/json")]
    public class ToDoController : ControllerBase
    {
        [HttpGet]
        public string IGetAll() 
        {
            var lResult = new List<ToDoList.TodoItem>();

            // create dummies
            for (var i = 0; i < 10; i++)
            {
                lResult.Add(new ToDoList.TodoItem() { Title = $"Title {i}", IsDone = false });
            }

            return JsonSerializer.Serialize(lResult);
        }
    }
}

问题:在我的 Blazor WebAssembly 项目中,对 API 的请求失败。Blazor WebAssembly 项目通过https://localhost:44340/托管,API 通过https://localhost:44349/托管。如何像使用 JavaScript 框架一样托管这两个项目?

4

2 回答 2

26

您可以,具体取决于您希望如何托管和部署您的解决方案:

2 个不同主机中的 API 和应用程序

在 API 项目启动类中启用 CORS:

public void Configure(IApplicationBuilder app)
{
    ...
    app.UseCors(configure => 
    {
         // configure here your CORS rule
    }
    ...
}

多合一主机

在您的 API 项目中

  • 添加包引用Microsoft.AspNetCore.Components.WebAssembly.Server
  • Startup在您的班级中设置 Blazor 服务器
public void Configure(IApplicationBuilder app)
{
    app.UseBlazorFrameworkFiles();
    ...
    app.UseEndpoints(endpoints => 
   {
       endpoints.MapDefaultControllerRoute();
       endpoints.MapFallbackToFile("index.html");
   });
}

您可以使用 : 创建示例解决方案dotnet new blazorwasm --hosted。它将使用 Blazor wasm 项目和主机创建解决方案。

文档

于 2020-04-03T12:44:41.883 回答
9

随着模板的最新更新dotnet new -i Microsoft.AspNetCore.Components.WebAssembly.Templates::3.2.0-preview2.20160.5

您可以通过运行以下命令,使用 ASP.NET Core Identity 和 IdentityServer 创建带有身份验证的 Blazor WebAssembly 应用设置:

dotnet new blazorwasm --hosted --auth Individual -o BlazorAppWithAuth1

这将创建:

  • 客户端 Blazor

  • 可用于 MVC、API 和 razor 页面的单个项目,其中包含可用于保护 API 调用的“内联”身份服务器

我被困在如何将 IS4 与 APi 放在同一个项目中(这是一个小项目,独立托管的 IDP 将是矫枉过正,我只想部署一个东西)但是这个模板显示了如何。

来源:https ://devblogs.microsoft.com/aspnet/blazor-webassembly-3-2-0-preview-2-release-now-available/

于 2020-04-30T09:07:01.157 回答