.NET6 创建ASP.NET Core MVC 没有 Startup 类、没有 ConfigureServices 方法

以官方文档(教程:在 ASP.NET MVC Web 应用中使用 EF Core 入门)为例,原文地址教程:在 ASP.NET MVC Web 应用中使用 EF Core 入门 | Microsoft Docs

 通过.NET6 创建的ASP.NET Core MVC项目没有没有 Startup 类和ConfigureServices 方法

参考其他项目解决方法如下:

新建一个HostingExtensions类(类名可以自己定义)

HostingExtensions类代码如下(具体代码可视自身情况修改,仅提供思路):

using ContosoUniversity.Data;
using Microsoft.EntityFrameworkCore;

namespace ContosoUniversity
{
    public static class HostingExtensions
    {
        public static WebApplication ConfigureServices(this WebApplicationBuilder builder)
        {
            // Add services to the container.
            builder.Services.AddControllersWithViews();

            //注册 SchoolContext
            builder.Services.AddDbContext<SchoolContext>(options =>
       options.UseMySql(builder.Configuration.GetConnectionString("MysqlConnection"), new MySqlServerVersion(new Version())));
            //添加数据库异常筛选器
            builder.Services.AddDatabaseDeveloperPageExceptionFilter();

            return builder.Build();
        }

        public static WebApplication ConfigurePipeline(this WebApplication app)
        {
            // Configure the HTTP request pipeline.
            if (!app.Environment.IsDevelopment())
            {
                app.UseExceptionHandler("/Home/Error");
                // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
                app.UseHsts();
            }

            app.UseHttpsRedirection();
            app.UseStaticFiles();

            app.UseRouting();

            app.UseAuthorization();

            //初始化数据库
            CreateDbIfNotExists(app);

            app.MapControllerRoute(
                name: "default",
                pattern: "{controller=Home}/{action=Index}/{id?}");

            return app;
        }
        /// <summary>
        /// 自定义的方法,初始化数据库
        /// </summary>
        /// <param name="host"></param>
        private static void CreateDbIfNotExists(IHost host)
        {
            using (var scope = host.Services.CreateScope())
            {
                var services = scope.ServiceProvider;
                try
                {
                    //从依赖注入容器中获取数据库上下文实例。
                    var context = services.GetRequiredService<SchoolContext>();
                    //调用 DbInitializer.Initialize 方法。当 Initialize 方法完成时释放上下文
                    DbInitializer.Initialize(context);
                }
                catch (Exception ex)
                {
                    var logger = services.GetRequiredService<ILogger<Program>>();
                    logger.LogError(ex, "An error occurred creating the DB.");
                }
            }
        }
    }
}

修改Program.cs代码

例如:

using ContosoUniversity;

var builder = WebApplication.CreateBuilder(args);



var app = builder
    .ConfigureServices()//HostingExtensions类中添加的方法
    .ConfigurePipeline();//HostingExtensions类中添加的方法



app.Run();
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ASP.NET Core MVC 可以使用 Entity Framework Core 连接数据。Entity Framework Core 是一个开源的 ORM(对象关系映射)框架,可以帮助我们简化数据访问代码的编写。 以下是连接数据库的基本步骤: 1. 在项目中添加 NuGet 包:Microsoft.EntityFrameworkCore 和 Microsoft.EntityFrameworkCore.SqlServer(或其他数据库提供程序)。 2. 在 `Startup.cs` 文件中的 `ConfigureServices` 方法中添加数据库上下文服务: ```c# services.AddDbContext<ApplicationDbContext>(options => options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection"))); ``` 其中,`ApplicationDbContext` 是你自己定义的数据库上下文,`DefaultConnection` 是你在 `appsettings.json` 文件中配置的数据库连接字符串。 3. 在 `ApplicationDbContext` 中定义数据模型和数据集,例如: ```c# public class Product { public int Id { get; set; } public string Name { get; set; } public decimal Price { get; set; } } public class ApplicationDbContext : DbContext { public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options) : base(options) { } public DbSet<Product> Products { get; set; } } ``` 4. 在控制器中注入数据库上下文,并使用它来访问数据: ```c# public class ProductController : Controller { private readonly ApplicationDbContext _context; public ProductController(ApplicationDbContext context) { _context = context; } public IActionResult Index() { var products = _context.Products.ToList(); return View(products); } } ``` 以上就是连接数据库的基本步骤。当然,具体实现可能会因为不同的需求而有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值