Может ли библиотека классов иметь файл App.config? - PullRequest
42 голосов
/ 27 января 2011

Вот как выглядит мое решение на данный момент:

enter image description here

В проекте Tutomentor.Branding я хотел бы сохранить информацию о брендинге в файле App.config, например имена, цвета и т. Д.

В проекте Tutomentor.Data файл App.config был создан, когда я добавил файл модели .edmx сущности.

Возможно ли это? Любые рекомендации?

При развертывании выводит ли COMBINE эти файлы App.config в один файл?

Ответы [ 6 ]

45 голосов
/ 27 января 2011

Нет, библиотеки классов могут содержать файлы настроек, но их значения будут определены в конфигурации приложения (web.config, app.config ...).

Это из-за переопределения параметров конфигурации.

Вам необходимо объявить разделы конфигурации сборок в app.config или web.config вашего приложения (WPF, SL, ASP.NET ...) и определить значение для определенного количества параметров, определенных правильные настройки сборки.

EDIT: Добавьте файл настроек в свой проект и добавьте параметр с областью применения, и ваша сборка будет выглядеть примерно так:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <sectionGroup name="applicationSettings" type="System.Configuration.ApplicationSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" >
            <section name="Assembly1.Settings1" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
        </sectionGroup>
    </configSections>
    <applicationSettings>
        <Assembly1.Settings1>
            <setting name="settingA" serializeAs="String">
                <value>a value</value>
            </setting>
        </Assembly1.Settings1>
    </applicationSettings>
</configuration> 

Теперь вам нужно перейти в свое приложение, и вам нужно скопировать и вставить группу разделов, а также объявления разделов и определение значений для параметров. Это все.

38 голосов
/ 25 сентября 2012

Хотя это более старая тема, она выглядит иначе.

Возможно, вы захотите взглянуть на проблему по-другому.

Предполагается, что библиотеки классов по своей природебыть портативнымТаким образом, любая необходимая конфигурация должна быть передана классу, а не находиться в библиотеке.Такие вещи, как строки подключения, по своей природе являются временными, поэтому имеет смысл поместить их в приложение-владелец.

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

Теперь у вас нет проблем с app.config для DLL, и тогда DLL действительно переносима.

6 голосов
/ 31 июля 2016

Просто создайте свой собственный файл XML, назовите его appConfig.xml или что-то подобное, попросите библиотеку классов прочитать файл, используя System.Xml вместо System.Configuration, и упакуйте файл вместе с вашей DLL.

4 голосов
/ 27 января 2011

Любая конкретная конфигурация из библиотеки app.config, вы должны поместить в свой файл конфигурации exe вручную.

0 голосов
/ 26 июня 2019

просто используйте эту общую конфигурацию для обработки d.injection служб в классе lib;

public void ConfigureServices(IServiceCollection services)
        {
            services.AddDbContext<AppDBContext>(options =>
            {
                options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection"),
                    assembly => assembly.MigrationsAssembly(typeof(AppDBContext).Assembly.FullName));
            });

            services.AddScoped<IUsersRepository, UsersRepository>();

            services.AddCors(o => o.AddPolicy("MyPolicy", builder =>
            {
                builder.AllowAnyOrigin()
                       .AllowAnyMethod()
                       .AllowAnyHeader();
            }));

            // configure strongly typed settings objects
            var appSettingsSection = Configuration.GetSection("AppSettings");
            services.Configure<AppSettings>(appSettingsSection);

            // configure jwt authentication
            var appSettings = appSettingsSection.Get<AppSettings>();
            var key = Encoding.ASCII.GetBytes(appSettings.Secret);
            services.AddAuthentication(x =>
            {
                x.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
                x.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
            })
            .AddJwtBearer(x =>
            {
                x.RequireHttpsMetadata = false;
                x.SaveToken = true;
                x.TokenValidationParameters = new TokenValidationParameters
                {
                    ValidateIssuerSigningKey = true,
                    IssuerSigningKey = new SymmetricSecurityKey(key),
                    ValidateIssuer = false,
                    ValidateAudience = false
                };
            });
            services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }
            else
            {
                // 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.UseCors("MyPolicy");
            app.UseHttpsRedirection();
            app.UseAuthentication();
            app.UseMvc();

        }

файл appsettingjson:

{
      "Logging": {
        "LogLevel": {
          "Default": "Warning"
        }
      },
      "ConnectionStrings": {
        "DefaultConnection": "server=.;database=TestAPP;User ID=yener1;password=yener1;"
      },
      "AppSettings": {
        "Secret": "REPLACE THIS WITH YOUR OWN SECRET, IT CAN BE ANY STRING"
      },
      "AllowedHosts": "*"

}

// commentout

  public static class Hasher
    {
        public static string ToEncrypt<T>(this T value)
        {
            using (var sha256 = SHA256.Create())
            {
                // Send a sample text to hash.  
                var hashedBytes = sha256.ComputeHash(Encoding.UTF8.GetBytes(value.ToString()));
                // Get the hashed string.  
                return BitConverter.ToString(hashedBytes).Replace("-", "").ToLower();
            }
        }
    }
public class AppDBContext : DbContext
{
    public AppDBContext(DbContextOptions options)
        : base(options)
    {
    }
    protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    {
        base.OnConfiguring(optionsBuilder);
    }

    protected override void OnModelCreating(ModelBuilder builder)
    {
        base.OnModelCreating(builder);
    }

    public DbSet<Users> Users { get; set; }
//BLL
    public class UsersRepository : IUsersRepository
    {
        private readonly AppDBContext _context;
        public UsersRepository(AppDBContext context)
        {
            _context = context;
        }
        public async Task<IEnumerable<Users>> GetUsers()
        {
            return await _context.Users.ToListAsync();
        }


[AllowAnonymous]
        [HttpPost("authenticate")]
        public IActionResult Authenticate([FromBody]UserDto userDto)
        {
            var user = _userService.Authenticate(userDto.Username, userDto.Password);

            if (user == null)
                return BadRequest("Username or password is incorrect");

            var tokenHandler = new JwtSecurityTokenHandler();
            var key = Encoding.ASCII.GetBytes(_appSettings.Secret);
            var tokenDescriptor = new SecurityTokenDescriptor
            {
                Subject = new ClaimsIdentity(new Claim[] 
                {
                    new Claim(ClaimTypes.Name, user.Id.ToString())
                }),
                Expires = DateTime.UtcNow.AddDays(7),
                SigningCredentials = new SigningCredentials(new SymmetricSecurityKey(key), SecurityAlgorithms.HmacSha256Signature)
            };
            var token = tokenHandler.CreateToken(tokenDescriptor);
            var tokenString = tokenHandler.WriteToken(token);

            // return basic user info (without password) and token to store client side
            return Ok(new {
                Id = user.Id,
                Username = user.Username,
                FirstName = user.FirstName,
                LastName = user.LastName,
                Token = tokenString
            });
        }
0 голосов
/ 27 января 2011

Ну, у библиотеки классов не может быть своего собственного app.config, но если вы определите свои настройки из библиотеки классов в app.config для exe-файла, библиотека классов сможет найти их для ..

Я немного неуверен, но я не думаю, что это объединит их автоматически, я думаю, вы должны сделать это вручную!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...