.Net Core 6新功能Minimal Api簡單使用
阿新 • • 發佈:2022-03-01
Minimal Api字面意思就是最小的api,用過.net core api的應該對core的web api機制不陌生。
首先新建一個web api空專案
建立空專案一定要取消勾選使用控制器,如果是建立.net core空專案則沒有該選項。建立完成開啟program
var builder = WebApplication.CreateBuilder(args); // Add services to the container. // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbucklebuilder.Services.AddEndpointsApiExplorer(); builder.Services.AddSwaggerGen(); var app = builder.Build(); // Configure the HTTP request pipeline. if (app.Environment.IsDevelopment()) { app.UseSwagger(); app.UseSwaggerUI(); } app.UseHttpsRedirection(); var summaries = new[] { "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching" }; app.MapGet("/weatherforecast", () => { var forecast = Enumerable.Range(1, 5).Select(index => new WeatherForecast ( DateTime.Now.AddDays(index), Random.Shared.Next(-20, 55), summaries[Random.Shared.Next(summaries.Length)] )) .ToArray(); return forecast; }) .WithName("GetWeatherForecast"); app.Run(); internal record WeatherForecast(DateTime Date, int TemperatureC, string? Summary) { public int TemperatureF => 32 + (int)(TemperatureC / 0.5556); }
還是熟悉的天氣預報,相較於之前wei api,minimalapi省去了控制器,更加精簡。執行程式
minimal api只要Get、Post、Put、Delete四種請求方式。
新增一個post方法
app.MapPost("/addUser", (string id) => { return $"{id} "; });
執行程式
引數預設成為了query傳參。接著修改一下addUser
app.MapPost("/addUser", (string id, UserModel user) => { return $"{id}:{user.Name} "; });
在原來的介面上新增一個實體接受引數,執行程式
實體引數預設成了body傳參。這是因為c#10的新特性,實體自動識別,目前我還沒有發現怎麼指定引數的接收方式。總結就是實體會用body傳參,int string這些會走query。如有不對歡迎指正糾錯。