2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
Startup.cs:n tehtävänä on hallita projektissa käytettyjä staattisia tiedostoja, putkia, palveluita, lokeja, reititystä, tietokantayhteyksiä, suodattimien rekisteröintiä jne., ja niitä käytetään kaikkien asiaan liittyvien ohjelmien käynnistyksessä ja käytössä.
Jos startup.cs-tiedostoa ei ole, voit luoda manuaalisesti uuden Startup.cs-luokan (Erityistä koodia voidaan muokata oman tilanteen mukaan.)
- public class Startup
- {
- public Startup(IConfiguration configuration)
- {
- Configuration = configuration;
- }
-
- public IConfiguration Configuration { get; }
-
- //在依赖注入容器中注册服务
- public void ConfigureServices(IServiceCollection services)
- {
- services.AddSingleton<IDbConfig.IDbConfig, DbConfig.DbConfig>();
- services.AddTransient<IBaseService, BaseService>();
-
- services.AddControllers();
- services.AddSwaggerGen(c =>
- {
- c.SwaggerDoc("v1", new OpenApiInfo { Title = "这里填写项目的名称", Version = "v1" });
-
- });
- }
- public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
- {
- if(env.IsDevelopment())
- {
- app.UseDeveloperExceptionPage();
- app.UseSwagger();
- app.UseSwaggerUI(c => c.SwaggerEndpoint("/swagger/v1/swagger.json", "这里填写项目的名称 v1"));
- }
- app.UseRouting();
- app.UseAuthorization();
- app.UseEndpoints(endpoints =>
- {
- endpoints.MapControllers();
- });
- }
- }
Yllä olevan kirjoittamisen jälkeen voit siirtyä toiseen vaiheeseen.
program.csin sisäinen päivityslogiikka
Kaikki Startup.cs-luokan vaatimat objektit ovat läsnä builder-objektissa, joten voimme välittää tarvittavat objektit ja menetelmille.
- var builder = WebApplication.CreateBuilder(args);
-
- var startup = new Startup(builder.Configuration);
- startup.ConfigureServices(builder.Services);
-
- var app = builder.Build();
- startup.Configure(app, builder.Environment);