내 연락처 정보
우편메소피아@프로톤메일.com
2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
Startup.cs의 기능은 프로젝트에서 사용되는 정적 파일, 파이프, 서비스, 로그, 라우팅, 데이터베이스 연결, 필터 등록 등을 제어하는 것이며 모든 관련 프로그램의 시작 및 실행에 사용됩니다.
Startup.cs가 없으면 새 Startup.cs 클래스를 수동으로 생성할 수 있습니다(특정 코드는 상황에 따라 수정될 수 있습니다.)
- 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();
- });
- }
- }
위 내용을 작성하신 후 2단계로 넘어가시면 됩니다.
program.cs 내부 업데이트 논리
Startup.cs 클래스에 필요한 모든 개체는 빌더 개체에 있으므로 필요한 개체를 및 메서드에 전달할 수 있습니다.
- var builder = WebApplication.CreateBuilder(args);
-
- var startup = new Startup(builder.Configuration);
- startup.ConfigureServices(builder.Services);
-
- var app = builder.Build();
- startup.Configure(app, builder.Environment);