Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/15: Рейтинг темы: голосов - 15, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 19.05.2021
Сообщений: 1

EF6 PostgreSQL SSL

19.05.2021, 19:00. Показов 3102. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Приветствую.


Пытаюсь подружить EF6, PostreSQL и SSL


Гугл довел до сих пор:
...
C#
1
2
3
4
5
                NpgsqlConnection conSql2 = new NpgsqlConnection();
                conSql2.ConnectionString = "<PGserver>;User Id=<UserName>;Password=<***>;Port=5432;Database=<DB>;SSL Mode=Require";
                conSql2.ProvideClientCertificatesCallback += ProvideClientCertificatesCallback;
                conSql2.Open();
}
...
C#
1
2
3
4
        static void ProvideClientCertificatesCallback(X509CertificateCollection clientCerts)
        {
            clientCerts.Add(new X509Certificate2(<UserName.pfx>, ""));
        }
...

И это работает.



Проблема в том что я не представляю как приклеить сертификат клиента к соединению в объектах EF6

в логи <PGserver> пишется
ВАЖНО: для подключения требуется годный сертификат клиента

при вызове
...
C#
1
2
3
            using (AppIdentityDbContext appIdentDB = new AppIdentityDbContext())
            {
                if (appIdentDB.Database.Exists()) blnIsExists = true;
...

взятого из учебника
...
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
    public class AppIdentityDbContext : IdentityDbContext<AppUser>
    {
        public AppIdentityDbContext() : base("name=DBcontext") {}
 
 
        static AppIdentityDbContext()
        {
            Database.SetInitializer<AppIdentityDbContext>(new IdentityDbInit());
        }
 
        public static AppIdentityDbContext Create()
        {
            return new AppIdentityDbContext();
        }
 
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
        }
 
    }   // public class AppIdentityDbContext : IdentityDbContext<AppUser>
...


строка подключения из web.config

XML
1
2
3
4
<connectionStrings>
  <add name="DBcontext" connectionString="<PGserver>;User Id=<UserName>;Password=<***>;Port=5432;Database=<DB>;SSL Mode=Require"
    providerName="Npgsql"  />
</connectionStrings>

entityFramework

XML
1
2
3
4
5
6
  <entityFramework>
    <providers>
      <provider invariantName="Npgsql" type="Npgsql.NpgsqlServices, EntityFramework6.Npgsql" />
    </providers>
    <defaultConnectionFactory type="Npgsql.NpgsqlServices, EntityFramework6.Npgsql" />
  </entityFramework>

system.data

XML
1
2
3
4
5
6
  <system.data>
    <DbProviderFactories>
      <remove invariant="Npgsql" />
      <add name="Npgsql Provider" invariant="Npgsql" description=".NET Framework Data Provider for PostgreSQL" type="Npgsql.NpgsqlFactory, Npgsql, Version=4.1.3.0, Culture=neutral, PublicKeyToken=5d8b90d52f46fda7" />
    </DbProviderFactories>
  </system.data>

для EFCore находил рекомендацию
...
C#
1
2
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    => optionsBuilder .UseNpgsql("...",  o => o.ProvideClientCertificatesCallback()...);
...


а вот как быть с EF6 совсем непонятно
прошу помощи.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.05.2021, 19:00
Ответы с готовыми решениями:

Entity Framework 6.0.1 + Postgresql(Npgsql.EF6 -PRe) или EF 6.0.1 + MongoDb ?
Добрый вечер уважаемые форумчане. Кто нибудь работал в связке с EntityFramework 6 с Postgresql через новый драйвер ? Кто работал...

PostgreSQL SSL
Здравствуйте! Помогите, пожалуйста, со следующей проблемой... ОС- Windows. Требуется настроить SSL на Postgresql 12....

Настроить PostgreSQL на связь по протоколу SSL
Здравствуйте, помогите разобраться. Требуется установить библиотеку OpenSSL и настроить PostgreSQL на связь по протоколу SSL. как это...

1
17 / 14 / 7
Регистрация: 04.02.2017
Сообщений: 486
03.10.2021, 23:47
Столкнулся с такой же проблемой только я использую EF Core. Вам удалось решить эту проблему?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.10.2021, 23:47
Помогаю со студенческими работами здесь

Как настроить SSL соединении в PostgreSQL на Windows между клиентом и сервером
Здравствуйте, у меня вопрос как настроить SSL соединении в PostgreSQL на Windows между клиентом и сервером, я с генерировал уже сертификат...

Pip is configured with locations that require TLS/SSL, however the ssl module in Python is not available
делаю pip3 install -r requirements.txt pip is configured with locations that require TLS/SSL, however the ssl module in...

Javax.net.ssl.SSLException: Unrecognized SSL message, plaintext connection?
Всем доброго времени суток, подскажите, пожалуйста, из-за чего ошибка? import java.io.*; import java.util.Properties; ...

SSL vs Fiddler (в рамках Silverlight) - объясните нужно ли иметь SSL?
Доброго времени суток. Я разрабатываю бизнес-приложение, которое работает с БД. Для безопасности трафика было принято решение купить...

IdHTTP (post) + SSL, ошибка Error connecting with SSL. EOF was observed violates the protocol
Добрый день! Подскажите пожалуйста, использую IdHTTP (post) + SSL , передаю SOAP запрос, но все падает в момент соединения, ошибка...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru