Partage de technologie

Il n'y a pas de classe de démarrage ni de méthode ConfigureServices dans le projet webapi ASP.NET Core créé via .NET6

2024-07-12

한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina

La fonction de Startup.cs est de contrôler les fichiers statiques, les canaux, les services, les journaux, le routage, les connexions à la base de données, l'enregistrement des filtres, etc. utilisés dans le projet, et sont utilisés dans le démarrage et l'exécution de tous les programmes associés.

S'il n'y a pas de startup.cs, vous pouvez créer manuellement une nouvelle classe Startup.cs (Le code spécifique peut être modifié selon votre propre situation.

  1. public class Startup
  2. {
  3. public Startup(IConfiguration configuration)
  4. {
  5. Configuration = configuration;
  6. }
  7. public IConfiguration Configuration { get; }
  8. //在依赖注入容器中注册服务
  9. public void ConfigureServices(IServiceCollection services)
  10. {
  11. services.AddSingleton<IDbConfig.IDbConfig, DbConfig.DbConfig>();
  12. services.AddTransient<IBaseService, BaseService>();
  13. services.AddControllers();
  14. services.AddSwaggerGen(c =>
  15. {
  16. c.SwaggerDoc("v1", new OpenApiInfo { Title = "这里填写项目的名称", Version = "v1" });
  17. });
  18. }
  19. public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
  20. {
  21. if(env.IsDevelopment())
  22. {
  23. app.UseDeveloperExceptionPage();
  24. app.UseSwagger();
  25. app.UseSwaggerUI(c => c.SwaggerEndpoint("/swagger/v1/swagger.json", "这里填写项目的名称 v1"));
  26. }
  27. app.UseRouting();
  28. app.UseAuthorization();
  29. app.UseEndpoints(endpoints =>
  30. {
  31. endpoints.MapControllers();
  32. });
  33. }
  34. }

Après avoir écrit ce qui précède, vous pouvez passer à la deuxième étape.

logique de mise à jour interne de program.cs

Tous les objets requis par la classe Startup.cs sont présents dans l'objet builder, nous pouvons donc transmettre les objets requis aux méthodes et .

  1. var builder = WebApplication.CreateBuilder(args);
  2. var startup = new Startup(builder.Configuration);
  3. startup.ConfigureServices(builder.Services);
  4. var app = builder.Build();
  5. startup.Configure(app, builder.Environment);