. net Core 3 / API / DI / Шаблон репозитория - PullRequest
0 голосов
/ 03 апреля 2020

Я пытаюсь создать веб-API в. net Core. Я хотел бы, чтобы этот API вызывал DLL с внедренным в нее шаблоном проектирования хранилища. Во всем этом я пытался использовать внедрение зависимостей, но у меня есть некоторые проблемы для управления контекстом для базы данных в репозитории.

Я бы хотел, чтобы в этом контексте был один новый контекст за время жизни вызова API.

Когда я пытаюсь выполнить свой код, у меня возникает исключение в строке CreateHostBuilder (args) .Build (). Run (); в Main.

Это исключение:

'Некоторые службы не могут быть построены' InvalidOperationException: невозможно разрешить службу для типа 'BX_Security_AccessBase.Context.SecurityContext' при попытке выполнить активировать 'BX_Security_AccessBase.Repository.UsersRepository'.

Я знаю, что код неполон и не будет работать полностью, но по крайней мере он должен сломаться намного позже, чем на самом деле. Я думаю, что допустил ошибку в архитектуре.

Ниже приведено много кода, но я не смог выделить свою проблему.

Спасибо всем.

В моем API у меня есть:

Startup.cs

public class Startup
{
    public Startup(IConfiguration configuration)
    {
        Configuration = configuration;
    }

    public IConfiguration Configuration { get; }

    public void ConfigureServices(IServiceCollection services)
    {
        services.AddControllers();

        services.AddScoped<IUsersRepository, UsersRepository>();
        services.AddScoped<IUserService, UserService>();
    }

    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }

        app.UseHttpsRedirection();

        app.UseRouting();

        app.UseAuthorization();

        app.UseEndpoints(endpoints =>
        {
            endpoints.MapControllers();
        });
    }
}

User.cs

public class User
{
    public User() {}

    public int UserId { get; set; }
    public string LastName { get; set; }
    public string FirstName { get; set; }
    public DateTime Birthdate { get; set; }
}

UserService.cs

public class UserService : IUserService
{
    private readonly AppSettings _appSettings;
    private readonly IUsersRepository _userRepository;

    public UserService(IOptions<AppSettings> appSettings, IUsersRepository userRepository)
    {
        _appSettings = appSettings.Value;
        _userRepository = userRepository;

    }

    public IEnumerable<User> GetAll()
    {
        return _userRepository.GetAllUsers().Select(u=> new User());
    }
}

IUserService.cs

public interface IUserService
{
    public IEnumerable<User> GetAll();
}

AppSettings.cs

 public class AppSettings
{
    public string Secret { get; set; }
}

UsersController.cs

[Route("api/[controller]")]
[ApiController]
public class UsersController : ControllerBase
{
    private IUserService _userService { get; }

    public UsersController(IUserService userService)
    {
        _userService = userService;
    }

    [HttpGet]
    public IActionResult GetAll()
    {
        var users = _userService.GetAll();
        return Ok(users);
    }
}

В DLL у меня есть:

SecurityContext.cs

public partial class SecurityContext : DbContext
{
    public SecurityContext(DbContextOptions<SecurityContext> options) : base(options) { }

    public DbSet<Users> Users { get; set; }

    protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    {
        if (!optionsBuilder.IsConfigured)
        {
            optionsBuilder.UseSqlServer("Data Source=; Database=BXDB; User Id=sa; Password=;");
        }
    }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity<Users>(entity =>
        {
            entity.HasKey(e => e.UserId).HasName("PK_User_UserId");

            entity.ToTable("Users", "sec");

            entity.Property(e => e.Birthdate).HasColumnType("date");

            entity.Property(e => e.FirstName)
                .HasMaxLength(50)
                .IsUnicode(false);

            entity.Property(e => e.LastName)
                .HasMaxLength(50)
                .IsUnicode(false);
        });

        OnModelCreatingPartial(modelBuilder);
    }

    partial void OnModelCreatingPartial(ModelBuilder modelBuilder);
}

Users.cs

public class Users
{
    public Users() { }

    public int UserId { get; set; }
    public string LastName { get; set; }
    public string FirstName { get; set; }
    public DateTime Birthdate { get; set; }
}

IUsersRepository.cs

public interface IUsersRepository
{
    public IQueryable<Users> GetAllUsers();
}

UsersRepository.cs

public class UsersRepository : IUsersRepository
{
    public readonly SecurityContext _dbContext;

    public UsersRepository(SecurityContext dbContext)
    {
        _dbContext = dbContext;
    }

    public IQueryable<Users> GetAllUsers()
    {
        return _dbContext.Users;
    }
}

1 Ответ

1 голос
/ 03 апреля 2020

'Некоторые службы не могут быть построены' InvalidOperationException: невозможно разрешить службу для типа 'BX_Security_AccessBase.Context.SecurityContext' при попытке активировать 'BX_Security_AccessBase.Repository.UsersRepository'.

Из-за ошибки вы должны зарегистрировать DbContext как сервис следующим образом:

public void ConfigureServices(IServiceCollection services)
{ 
        var connection = @"Server=(localdb)\mssqllocaldb;Database=BXDB;Trusted_Connection=True;ConnectRetryCount=0";
        services.AddDbContext<DLL.Models.SecurityContext>(options => options.UseSqlServer(connection, x => x.MigrationsAssembly("DLL")));

        services.AddControllers();

        services.AddScoped<IUsersRepository, UsersRepository>();
        services.AddScoped<IUserService, UserService>();
 }
...