安装aspire
查看vs版本
data:image/s3,"s3://crabby-images/9ae73/9ae736ca65c7d511b66b936577dac350ab5c5bd6" alt=""
我这的版本是17.9.7,不支持aspire,所以需要升级
更新VS
点击 帮助->检查更新
点击更新
data:image/s3,"s3://crabby-images/d0257/d0257648696d86a40b73f1ee67af3f3f5f7f5311" alt=""
静等安装升级
data:image/s3,"s3://crabby-images/0727f/0727fb4f8b33492c8dc04eaf6a560f61b62dd60d" alt=""
创建aspire项目
data:image/s3,"s3://crabby-images/27916/2791670837f43387a348f146dbdce25026fcd934" alt=""
data:image/s3,"s3://crabby-images/d8da5/d8da56a225b49abd0ed6a86d6de8ac552ff5d066" alt=""
项目创建成功,如下图
data:image/s3,"s3://crabby-images/fa61b/fa61b135b9f268925ea28a2639274e88eb759419" alt=""
运行Aspire项目
在AspireApp1.AppHost的launchSettings.json文件中加 "ASPIRE_ALLOW_UNSECURED_TRANSPORT": "true"
json
{
"$schema": "https://json.schemastore.org/launchsettings.json",
"profiles": {
"http": {
"commandName": "Project",
"dotnetRunMessages": true,
"launchBrowser": true,
"applicationUrl": "http://localhost:15177",
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development",
"DOTNET_ENVIRONMENT": "Development",
"DOTNET_DASHBOARD_OTLP_ENDPOINT_URL": "http://localhost:19239",
"DOTNET_RESOURCE_SERVICE_ENDPOINT_URL": "http://localhost:20241",
"ASPIRE_ALLOW_UNSECURED_TRANSPORT": "true"
}
}
}
}
运行AspireApp1.AppHost项目
data:image/s3,"s3://crabby-images/69b97/69b97c24bf44183fe6f8b952fdbadf85c299fa4b" alt=""
访问AspireApp1.Web项目
data:image/s3,"s3://crabby-images/1b9f3/1b9f34cbd638cb13e69de42b1f1ed4d1974dbb5b" alt=""
data:image/s3,"s3://crabby-images/ad487/ad4870c483a2c77411fcc627b4e03c51b3918619" alt=""
这里只要运行AspireApp1.AppHost项目就可以了
分析
看AspireApp1.AppHost项目的Program.cs文件,这里运行了两个项目
c#
var builder = DistributedApplication.CreateBuilder(args);
var cache = builder.AddRedis("cache");
var apiService = builder.AddProject<Projects.AspireApp1_ApiService>("apiservice"); //这里是后端项目
builder.AddProject<Projects.AspireApp1_Web>("webfrontend")//这里是前端项目
.WithExternalHttpEndpoints()
.WithReference(cache)
.WithReference(apiService);
builder.Build().Run();
AspireApp1.Web这里注入了对apiservice的访问
c#
using AspireApp1.Web;
using AspireApp1.Web.Components;
var builder = WebApplication.CreateBuilder(args);
// Add service defaults & Aspire components.
builder.AddServiceDefaults();
builder.AddRedisOutputCache("cache");
// Add services to the container.
builder.Services.AddRazorComponents()
.AddInteractiveServerComponents();
builder.Services.AddHttpClient<WeatherApiClient>(client => client.BaseAddress = new("http://apiservice")); //这里注入后端项目的API服务
var app = builder.Build();
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error", createScopeForErrors: true);
}
app.UseStaticFiles();
app.UseAntiforgery();
app.UseOutputCache();
app.MapRazorComponents<App>()
.AddInteractiveServerRenderMode();
app.MapDefaultEndpoints();
app.Run();
看WeatherApiClient.cs文件
c#
namespace AspireApp1.Web;
public class WeatherApiClient(HttpClient httpClient)
{
public async Task<WeatherForecast[]> GetWeatherAsync(int maxItems = 10, CancellationToken cancellationToken = default)
{
List<WeatherForecast>? forecasts = null;
await foreach (var forecast in httpClient.GetFromJsonAsAsyncEnumerable<WeatherForecast>("/weatherforecast", cancellationToken))//调用后端API获取天气预报数据
{
if (forecasts?.Count >= maxItems)
{
break;
}
if (forecast is not null)
{
forecasts ??= [];
forecasts.Add(forecast);
}
}
return forecasts?.ToArray() ?? [];
}
}
public record WeatherForecast(DateOnly Date, int TemperatureC, string? Summary)
{
public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);
}
作者
吴晓阳 微信号:shiningrise